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数据 库 技术 是 计算 机 科学 技术 中 发 展 最 快 的 领域 之 一 ， 也 是 应 用 最 广泛 的 技术 之 一 
它 已 成 为 计算 机 信息 系统 与 应 用 系统 的 核心 技术 和 重要 基础 。“ 数 据 库 系 统 原 理 及 应 用 ” 
是 一 门 全 面 阐述 数据 库 系统 的 理论 、 技 术 和 方法 的 课程 ， 是 计算 机 科学 本 科 专 业 的 主干 课 
程 ， 更 是 一 门 理论 与 实践 紧密 联系 的 课程 。 

为 使 理论 教学 与 实践 教学 紧密 结合 ， 注 重读 者 实践 能 力 的 培养 ， 本 书 从 课程 实验 和 课 
程 设计 出 发 ， 通 过 实验 和 设计 环节 使 读者 能 深入 理解 和 掌握 数据 库 系 统 的 基本 理论 、 数 据 
库 设计 的 基本 方法 、DBMS 的 使 用 以 及 数据 库 系统 的 管理 和 维护 ， 培 养 读者 的 理论 分 析 能 
力 和 综合 动手 能 力 ， 使 其 初步 具备 开发 数据 库 应 用 系统 的 能 力 。 

本 书 内 容 紧 密 结合 主教 材 的 学 习 内 容 ， 由 浅 入 深 、 循序 渐进 ， 力 求 通过 实践 训练 让 读者 
了 解数 据 库 管 理 系统 的 基本 原理 和 数据 库 系 统 设计 的 方法 , 培养 读者 应 用 及 设计 数据 库 的 能 
力 。 全 书 分 为 三 大 部 分 ， 第 一 部 分 为 实验 指导 ， 第 二 部 分 为 课程 设计 ， 第 三 部 分 为 附录 。 

第 一 部 分 密切 结合 主教 材 的 知识 体系 ， 共 设计 11 个 实验 ， 为 读者 进一步 理解 、 应 用 
数据 库 系 统 的 理论 打下 坚实 的 基础 。 课 程 实验 采用 SQL Server 2012 系统 作为 实验 环境 , 对 
实验 所 需 的 预备 知识 、 实 验 目的 、 实 验 内 容 和 实验 步骤 都 进行 了 精心 设计 ， 在 实验 的 最 后 
还 给 出 了 实验 报告 要 求 和 实验 思考 题 。 为 便于 读者 完整 理解 整个 实验 体系 和 实验 要 求 ， 该 
部 分 开始 就 给 出 了 课程 实验 规范 和 课程 教学 大 纲 。 

第 二 部 分 介绍 了 课程 设计 概述 、 课 程 设计 规范 、 课 程 设计 大 纲 、 课 程 设计 实施 方案 和 课 
程 设计 实例 。 通 过 课程 设计 的 训练 ， 为 后 续 的 毕业 设计 和 毕业 论文 撰写 打下 坚实 的 基础 。 

第 三 部 分 介绍 教材 主要 章节 (第 1 一 7 章 ) 的 知识 点 、 章 节 练 习题 和 模拟 试题 ， 作 为 读者 
进行 课程 学 习 的 补充 材料 。 

本 书 由 长 期 承担 “数据 库 系统 原理 及 应 用 ”课程 教学 、 具 有 丰富 教学 经 验 的 一 线 教师 
编写 ， 在 编写 过 程 中 将 长 期 积累 的 教学 经 验 和 体会 融入 知识 系统 ， 力 求 做 到 通俗 易 懂 ， 概 
念 清楚 ， 内 容 丰富 ， 理 论 与 应 用 并 重 ， 从 而 培养 学 生 的 应 用 技能 。 

本 书 由 广东 理工 学 院 胡 致 杰 、 胡 羽 沫 和 李 代 平 主编 ， 参 与 本 书 编写 的 还 有 陈 玉 、 林 显 
宁 、 梁 玉英 等 人 。 本 书 在 编写 和 出 版 过 程 中 ， 得 到 广东 理工 学 院 、 清 华 大 学 出 版 社 和 部 分 
高 等 院 校 相关 教师 的 大 力 支持 和 帮助 ， 同 时 也 参考 了 大 量 相 关 教材 、 资 料 和 文献 ， 在 此 表 
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由 于 编者 水 平 有 限 ， 书 中 难免 存在 下 漏 之 处 ， 息 切 希 望 广 大 读者 批评 指正 。 非 常 欢迎 
联系 交流 与 合作 ， 邮 箱 为 wkservice@163.com。 

本 书 课件 下 载 : 国 咏 守信? 国 

















编 者 
2018 年 4 月 


第 1 章 课程 实验 概述 …………………… 3 
1.1 实验 的 地 位 与 作 上 
1.2 实验 的 目的 与 意义 


第 2 章 课程 实验 规范 ………… 
2.1 课程 实验 工作 内 容 … 
答 报 告 文本 结构 及 写作 
规范 ER OE ER 6 
2.3 ”课程 实验 其 他 相关 要 求 ……………… 9 
第 3 章 课程 教学 大 纲 
3.1 大 纲 说 明 
3.2 ”理论 教学 大 纲 
3.3 实验 教学 大 纲 






















































实验 1 数据 库 和 基本 表 操 作 21 
实验 2 数据 操作 …… “31 
实验 3 单 表 查 询 : “36 
实验 4 多 表 连 接 查 询 … “42 
实验 5 嵌 套 查询 与 集合 查询 …………… 45 
实验 6 索引 与 视图 

实验 7 TSQL 程序 设计 

实验 8 存储 过 程 





实验 9 
实验 10 数据库 的 安全 
实验 11 数据 库 备份 和 还 原 …………… 87 







录 


第 二 部 分 课程 设计 

第 5 章 课程 设计 概述 …………………… 95 
5.1 课程 设计 的 特性 … 
5.2 ”制定 课程 设计 规范 
5.3 ”课程 设计 的 课程 目标 ……………… 96 
5.4 ”课程 设计 的 限制 条 件 ………………96 
5.5 ”形成 课程 设计 理念 ee 97 


第 6 章 课程 设计 规范 ……………………… 98 
6.1 课程 设计 工作 规范 
6.2 ”课程 设计 (论文 ) 撰 写 规范 ………… 100 
6.3 ”设计 报告 参考 模板 … 
6.4 ”课程 设计 (论文 ) 任 务 书 … 

第 7 章 课程 设计 大 纲 … 

第 8 章 课程 设计 实施 方案 ……………… 117 

第 9 章 课程 设计 实例 ……………………… 
9.1 课程 设计 任务 书 
92 课程 设计 报告 


第 三 部 分 附录 


附录 A 章节 知识 点 169 
附录 B 章节 练习 题 ……………… 191 
附录 C， 模 抽 斌 卫 eeemstmesnies 221 














09 





分 ”实验 指导 


课程 实验 概述 
课程 实验 规范 
课程 教学 大 纲 
课程 实验 


第 1 章 ”课程 实验 概述 


在 实践 教学 中 ， 教 师 是 学 生 学 习 科学 知识 的 支持 者 和 引导 者 。 引 导 学 生 主动 亲历 科学 
究 过 程 ， 将 有 利于 激发 学 生 学 习 科学 知识 的 主动 性 。 科 学 探究 是 学 生 学 习 科学 知识 的 重 
要 方式 ， 但 不 是 唯一 方式 。 根 据 教学 内 容 的 不 同 ， 学 生 的 学 习 方式 可 以 是 多 样 的 ， 教 学 中 
要 根据 具体 的 教学 目标 和 内 容 采 用 不 同 的 教学 方式 与 策略 ， 让 学 生 将 探究 式 的 学 习 与 其 他 
方式 的 学 习 充分 结合 起 来 ， 以 获得 最 佳 的 学 习 效果 。 


1.1 实验 的 地 位 与 作用 


实验 课 不 仅仅 是 通过 对 理论 和 定律 的 验证 ， 使 学 生 巩 固 和 理解 基本 理论 知识 、 掌 握 基 
本 技能 , 更 重要 的 是 传授 给 学 生 实验 的 设计 思想 ,包括 实验 方案 的 制定 、 实 验 装置 的 设计 、 
实验 数据 的 选择 、 实 验 仪器 的 配置 等 ， 培 养 其 判断 、 想 象 思维 的 能 力 ， 解 决 实 际 问题 与 总 
结 、 概 括 的 能 力 。 

实验 作为 理工 科教 学 中 的 重要 内 容 和 重要 方法 ， 对 学 生 掌 握 理 工科 知识 、 科 学 研究 方 
法 、 实 验 技能 以 及 培养 创新 精神 ， 都 具有 重要 的 地 位 和 作用 。 但 现实 客观 现象 可 能 受 干扰 
因素 过 多 ， 学 生 无 法 通过 自然 现象 加 以 理解 ， 故 只 有 通过 专门 设计 的 实验 帮助 学 生 真正 掌 
握 学 科 知识 。 





1.2 实验 的 目的 与 意义 


1. 目的 

(1) 通过 实验 训练 ， 消 化 吸收 课堂 讲授 内 容 。 

(2) 通过 调试 、 验 证 典型 例题 或 习题 ， 积 累 调试 程序 的 经 验 。 

(3) 通过 完成 设计 类 、 综 合 类 实验 ， 逐 步 培养 学 生 的 设计 能 力 、 用 计算 机 解决 实际 问 
题 的 能 力 。 

2. 意义 

(D 有 助 于 加 深 对 课程 的 理解 。 课 堂上 学 习 的 是 基础 理论 知识 ， 对 于 如 何 用 程序 语言 
来 描述 所 学 知识 还 有 一 定 的 难度 。 通 过 课程 实验 ， 可 以 真正 理解 其 内 涵 。 
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(2) 有 利于 逻辑 思维 的 锻炼 。 课 程 实验 能 直接 有 效 地 训练 学 生 的 创新 思维 ， 培 养 其 分 
析 问 题 、 解 决 问题 的 能 力 。 即 使 是 一 个 简单 的 程序 ， 依 然 需要 学 生 有 条 不 率 地 构思 。 

(3) 有 利于 培养 严谨 认真 的 学 习 态 度 。 在 课程 实验 过 程 中 ， 如 果 不 够 认真 或 细心 ， 可 
能 导致 实验 错误 ， 从 而 无 法 得 出 正确 的 实验 结果 ; 随 之 而 来 的 反复 调试 、 反 复 修改 的 过 程 ， 
其 实 也 是 对 学 生 严谨 治学 的 锻炼 。 


第 2 章 ”课程 实验 规范 


课程 实验 是 培养 学 生 运用 课程 的 基础 理论 和 技能 解决 实际 问题 ， 并 进一步 提高 学 生 
专业 基本 技能 、 创 新 能 力 的 重要 实践 的 教学 环节 。 通 过 课程 实验 ， 学 生 可 以 进行 设计 方法 
的 初步 训练 ， 能 用 文字 、 图 形 和 现代 化 方法 系统 地 、 正 确 地 表达 实验 和 研究 成 果 。 为 使 课 
程 实验 教学 工作 更 规范 ， 提 高 人 才 培养 质量 ， 特 制定 本 规范 。 


2.1 课程 实验 工作 内 容 


课程 实验 的 目的 主要 是 通过 课程 实验 环节 的 实践 活动 ， 帮 助 学 生 理论 联系 实际 ， 提 高 
学 生 实践 能 力 和 创新 能 力 ， 并 培养 学 生 技术 总 结 和 撰写 报告 的 基本 技能 。 

课程 实验 教学 工作 需要 完成 如 下 内 容 。 

1. 制定 符合 学 校 统一 格式 要 求 的 课程 实验 教学 大 纲 

教学 大 纲 包 括 课程 名 称 、 课 程 编码 、 课 程 性 质 、 学 时 学 分 、 适 用 专业 、 配 套 教 材 (讲义 ) 
与 指导 书 、 实 验 课 的 任务 及 性 质 与 目的 、 实 验 课 的 基本 理论 、 实 验方 式 与 基本 要 求 、 考 术 
方式 与 评分 方式 以 及 实验 项 目 设置 与 内 容 提要 。 

2. 指定 课程 实验 指导 书 

指定 正式 出 版 的 或 导师 编 所 的 课程 实验 指导 书 ， 作 为 学 生 课程 实验 的 重要 参考 资料 
Ea 

3. 制定 课程 实验 任务 书 

课程 实验 任务 书 应 该 包含 课程 实验 的 题目 名 称 和 内 容 要 求 。 根 所 课程 特点 ， 实 验 可 
以 提供 多 个 内 容 ， 明 确 每 个 实验 的 类 型 以 及 必 做 或 选 做 。 其 中 ， 实 验 划分 为 演示 性 、 验 证 
性 、 综 合 性 和 设计 性 四 种 类 型 。 

4. 制定 课程 实验 评分 标准 

制定 科学 的 、 可 操作 的 课程 实验 评分 标准 。 应 采用 课程 实验 的 质量 测评 和 课程 实验 
报告 的 质量 评价 两 类 评分 标准 指标 ， 进 行 课程 实验 综合 评分 。 其 中 ， 课 程 实验 报告 的 质量 
评价 的 评分 权重 不 低 于 20%。 

5. 课程 实验 报告 

在 课程 实验 导师 指导 下 ， 学 生 完成 撰写 符合 规范 要 求 的 课程 实验 报告 。 
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6. 课程 实验 学 生 分 组 要 求 

为 了 培养 学 生 的 基本 实验 技能 ， 依 据 “ 人 人 动手 操作 ”的 原则 ， 学 生 实验 分 组 作 如 下 
要 求 : 

对 于 单 台 设 备 ， 学 生 10 人 /组 ; 对 于 5 台 以 下 实验 设备 ， 学 生 5 一 6 人 /组 ; 对 于 5 台 
以 上 设备 ， 学 生 1 一 2 人 /组 。 





2.2 课程 实验 报告 文本 结构 及 写作 规范 


1. 报告 结构 概述 

报告 内 容 以 文字 为 主 ， 图 表 为 辅 。 课 程 实验 报告 必须 包含 以 下 内 容 : 封面 、 目 录 、 正 
文 、 参 考 文献 、 附 录 。 并 依 序 装订 成 山 。 其 中 ， 参 考 文献 和 附录 部 分 依据 各 课程 特点 自行 
确定 选用 。 纸 张 规格 均 为 A4。 


2. 封面 


课程 实验 报告 采用 统一 封面 ( 详 见 附件 2-1)。 学 生 需 要 填写 课程 名 称 、 专 业 班 级 、 学 
号 、 姓 名 、 指 导 教师 和 报告 日 期 。 其 中 ， 课 程 名 称 是 指 课程 实验 所 属 的 课程 名 称 ， 如 计算 
机 组 成 原理 课程 实验 的 报告 ， 填 写 “ 计 算 机 组 成 原理 ”; 专业 班级 填写 “专业 名 称 + 班 级 
编号 ”， 如 “计算 机 科学 与 技术 201802 班 ”。 

3. 目录 

目录 是 课程 实验 报告 的 纲要 。 正 文 的 各 级 标题 (一 般 最 多 取 三 级 )、 参 考 文献 和 附录 都 
应 编 入 目录 ， 但 目录 本 身 不 出 现在 其 中 。 

目录 要 求 层次 清晰 ， 含 标题 及 对 应 的 起 始 页 号 。 目 录 最 后 的 “参考 文献 ”和 “ 附 

课程 实验 报告 正文 、 参 考 文献 和 附录 页 面 ， 使 用 “1，2，3，...” 编 连续 页 码 。 页 码 
应 标 在 页 面 的 右 下 角 。 

目录 中 正文 的 各 级 标题 名 称 、 参 考 文献 和 附录 及 其 对 应 的 起 始 页 号 ， 务必 与 报告 中 
正文 的 各 级 标题 名 称 、 参 考 文献 和 附录 及 其 对 应 的 起 始 页 号 保持 一 致 。 

4. 正文 


正文 应 按 目录 中 编排 的 章节 依次 撰写 ， 要 求 计算 正确 ， 论 述 清楚 ， 文 字 简 练 通顺 ， 
插图 简明 ， 书 写 整洁 。 文 中 图 、 表 按 制 图 、 制 表 要 求 绘制 。 

课程 实验 报告 正文 格式 ， 详 见 本 章 附件 2-2。 因 为 实验 类 型 和 课程 的 不 同 特点 ， 每 个 
实验 的 详细 提纲 ， 或 在 指导 教师 的 指导 下 由 学 生 自行 拟定 ， 或 由 指导 教师 统一 规定 。 

正文 统一 采用 小 四 号 宋体 /Times New Roman 和 1.25 倍 行距 。 




















(1) 正文 章节 标题 
告 章 标题 称 为 一 级 标题 ， 章 内 小 节 标 题 依 次 分 为 二 级 标题 、 三 级 标题 等 。 一 级 标 

题 的 编号 用 数字 1，2，… 编 制 ; 二 级 标题 的 编号 用 1.1，1.2，… 编 制 ; 三 级 标题 的 编号 用 
1.1.1，1.2.1，… 编 制 ; 四 级 及 以 后 各 级 标题 可 以 此 类 推 。 建 议 标题 不 超过 3 级 (如 1.1.1)， 
超出 部 分 可 根据 需要 使 用 (1)，Q@，A，a)，… 等 形式 描述 。 

标题 编号 与 标题 文字 之 间 均 用 空格 隔 开 ， 如 “1 引言 ”“2.1 需求 分 析 ”。 报 告 正文 
的 一 级 标题 ( 章 ) 须 另 起 一 页 居中 排版 。 

(2) 正文 中 的 图 

正文 中 所 有 插图 要 求 图 面 整洁 ， 布 局 合理 ， 线 条 粗细 均匀 ， 圆 弧 连 接 光 滑 ， 尺 寸 标 
注 规范 。 所 有 曲线 、 图 表 、 线 路 图 、 流 程 图 、 程 序 框图 、 示 意图 等 ， 必 须 按 国家 规定 标准 
或 工程 要 求 采 用 计算 机 或 手工 绘制 。 
所 有 插图 均 应 有 图 号 和 图 名 。 图 号 按 章 编 ， 如 第 2 章 的 图 为 图 2.1、 图 22、…， 第 3 
章 的 图 为 图 3.1、 图 3.2、…。 图 名 是 插图 的 名 称 ， 扼 要 概括 图 的 内 容 ， 字 数 不 宜 太 多 。 图 
号 和 图 名 写 在 图 下 方 ， 并 相对 于 图 居中 排版 。 少 数 图 有 图 注 ， 图 注 写 在 图 下 面 且 字号 应 比 
图 号 、 图 名 的 字 小 一 号 ， 图 名 和 图 注 后面 均 不 加 标点 符号 。 








所 有 插图 均 应 在 正文 中 予以 引用 。 引 用 某 插图 时 ， 一 般 写 为 “…… 见 图 xy” 或 “图 
X.y 是 ……”。 正 文中 的 插图 均 须 安排 在 文中 第 一 次 引用 到 该 图 的 正文 下 面 ， 要 求 先 见 


文 ， 后 见 插图 ， 且 图 一 般 不 跨 页 绘制 。 

图 中 文字 、 图 号 和 图 名 ， 统 一 采用 小 五 号 宋体 。 

(3) 正文 中 的 表 

表格 由 表 号 、 表 名 、 表 头 、 表 身 等 组 成 。 表 号 按 章 编 ， 如 第 2 章 的 表 为 表 2.1、 表 
2.2、…， 第 3 章 的 表 为 表 3.1、 表 3.2、…。 表 名 是 表格 的 名 称 ， 扼 要 概括 表 的 内 容 ， 字 数 
不 宜 太 多 。 表 号 、 表 名 放 在 表 的 正 上 方 ， 相 对 于 表 身 居中 排版 。 表 号 及 表 名 后 不 加 标点 符 
号 。 表 头 包 括 栏 头 、 行 头 ， 与 表 身 一 起 构成 表格 的 主体 。 表 中 的 紧 格 称 为 栏 ， 横 格 称 为 
行 。 表 身 的 内 容 ， 一 般 包 括 数据 、 文 字 、 公 式 和 表 图 等 。 表 内 的 数据 对 应 位 要 对 齐 。 少 数 
表 有 表 注 ， 表 注 写 在 表 下 面 ， 且 字号 应 比 表 号 、 表 名 的 字 小 一 号 。 


所 有 表格 均 应 在 正文 中 予以 引用 。 引 用 某 表 格 时 ， 一 般 写 为 “…… 见 表 xy” 或 “ 表 
xy 是 ……”。 表 格 应 尽量 靠近 正文 的 叙述 ， 一 般 应 先 见 文 ， 后 见 表 ， 表 不 跨 节 。 表 格 允 








许 转 页 。 表 格 转 页 部 分 可 以 不 写 表 号 和 表 名 ， 但 要 重复 书写 表 头 ， 并 在 表 头 右上 角 写 
“( 续 )” 字 标注 。 

表 中 文字 、 表 号 和 表 名 ， 统 一 采用 小 五 号 宋体 。 

(4) 正文 中 的 公式 

公式 一 般 男 行 居中 写 ， 公 式 末 不 加 标点 符号 。 若 公式 前 有 文字 ， 如 例 、 解 、 证 、 假 
定 等 ， 文 字 顶 格 写 ， 公 式 仍 居中 写 。 一 行 写 不 下 时 ， 公 式 允许 转行 。 公 式 转 行 需 处 理 得 
当 ， 做 到 既 意义 正确 ， 又 使 版 面 美观 匀称 。 

公式 要 有 编号 ， 公 式 编号 按 章 编 ， 如 第 2 章 的 公式 为 (2.1)、(2.2)、…， 第 3 章 的 公式 
为 (3.1)、(3.2)、…。 公 式 编号 写 在 公式 右 侧 行 末 项 边线 ， 并 加 圆 括号 。 
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公式 一 般 应 在 正文 中 予以 引用 ， 引 用 时 以 公式 编号 指示 公式 。 正 文中 常 有 公式 中 表 
示 量 的 符号 说 明 ， 采 用 “ 式 中 ”二 字 作 为 标识 。 一 般 可 写成 接 排 形式 ， 如 “ 式 中 ，A 





5. 参考 文献 


参考 文献 属于 正文 后 的 辅 文部 分 ， 是 正文 中 对 某 一 著作 或 论文 等 文献 内 容 的 参考 或 
借鉴 过 的 文献 。 所 列 参 考 文献 一 般 只 限于 作者 亲自 阅读 过 且 发 表 在 公开 出 版 物 上 的 文献 ， 
非 此 类 文献 一 般 不 能 作为 参考 文献 ， 慎 用 互联 网 上 的 文献 。 

文 后 所 列 参考 文献 是 报告 中 引用 文献 出 处 的 目录 表 ， 务 必 在 正文 中 出 现 过 引用 标 
识 。 列 示 参 考 文献 时 ， 要 求 著录 项 目 齐全 ， 格 式 规范 ， 其 要 点 如 下 。 

(1) 允许 列 入 公开 出 版 的 图 书 、 期 刊 的 文章 、 专 利 、 硕 士 和 博士 论文 、 科 技 报告 等 。 
未 公开 发 表 的 文章 和 非 正式 出 版 物 等 请 勿 列 入 。 

(2) 文献 的 著录 项 目 及 其 次 序 ， 有 以 下 几 种 情况 。 

@ 图 书 : [序号 ] 作者 . 书 名 .版 本 (第 x 版 ). 译 者 .出 版 地 : 出 版 者 ， 出 版 年 : 起 页 - 止 页 . 

@ 期 刊 ， [序号 ] 作者 .文章 名 称 .期 刊 名 称 ， 年 号 ， 卷 号 (期 号 ): 起 页 - 止 页 . 

会 议论 文集 : [序号 ] 作者 .文章 名 称 . In( 见 ): 整 本 文集 的 编者 姓名 ed.( 多 编者 用 eds.). 
文集 名 .会 址 .开会 年 .出 版 地 : 出 版 者 ， 出 版 年 : 起 页 - 止 页 . 

@ 专利 [序号] 专利 申请 者 .专利 题名 .专利 国 别 ， 专 利文 献 种 类 ， 专利 号 ， 出 版 年 : 
起 页 - 止 页 . 

@ 学 位 论文 : [序号 ] 作者 .题名 [博士 或 硕士 学 位 论文 ]. 保 存 地 点 : 保存 单位 (如 华中 科 
技 大 学 )， 年 份 . 

@ 网 页 : [序号 ] URL: 网 络 地 址 ， 如 URL: http://www.cbs.dtu.dk/services. 

(3) 所 有 参考 文献 均 应 在 正文 中 予以 引用 ， 引 用 方式 分 以 下 两 种 情况 。 

@ 在 正文 中 附注 参考 文献 时 ， 把 所 有 文献 的 号 码 连同 方 括号 一 并 放 在 加 注 处 的 右上 


角 ， 例 如 : “TCPHPE-9] 是 ……”。 
@ 所 提 及 的 文献 作为 叙述 文中 的 直接 说 明 语 时 ， 其 编号 连 方 括号 应 与 正文 并 排 ， 例 
1 光 sses 见 文献 [2,3-6]”。 


方 插 号 内 可 为 单个 文献 的 编号 ， 如 [2]; 也 可 为 若干 参考 文献 编号 的 罗列 ， 如 [2.6.9]; 
也 可 为 用 “x-y” 表 示 的 序号 区 间 ， 如 [3-6]; 或 以 上 形式 的 组 合 ， 如 [2,3-6]。 

(4) 其 他 注意 事项 。 

@ 序号 编制 顺序 : 参考 文献 的 序号 依据 引用 先后 编制 ， 即 第 一 篇 被 引用 的 参考 文献 
编号 为 1， 第 二 篇 被 引用 的 参考 文献 编号 为 2， 以 此 类 推 。 

@ 文献 若 属 第 1 版 ， 则 参考 文献 著录 项 目 “ 版 次 ”一 项 可 略 。 

图 车 为 多 作者 的 文献 ， 则 作者 之 间 用 逗 点 “, ” 隔 开 。 作 者 超过 3 个 时 ， 只 著录 前 3 
个 ， 其 后 加 “等 ”( 英 文 用 “et al.”)。 外 文 作者 采用 姓 在 前 、 名 在 后 的 书写 形式 。 外 国人 
的 名 可 以 缩写 为 首 字母 ， 缩 写 的 名 后 不 加 圆 点 “.”。 

@ 无 出 版 地 的 中 文 文献 要 注 明 “[ 出 版 地 不 详 ]”， 英 文 文献 注 明 [S.L.]; 无 出 版 者 的 



























































中 文 文献 注 明 “[ 出 版 者 不 详 ]”， 英 文 文献 注 明 [S.N.]。 
@ 网 页 作为 参考 文献 ， 除 非 必要 ， 尽 量 少 用 。 
@ 参考 文献 引用 时 标注 位 置 不 能 在 章 、 节 的 标题 上 ， 如 “2.3 软件 测试 方法 概述 
039l» 为 不 正确 的 标注 ， 必 须 引用 在 正文 的 文字 段落 中 。 同 时 ， 标 注 位 置 要 在 句 末 的 标点 























符号 以 内 ， 不 能 先 写 标点 符号 ， 再 标 参考 文献 ， 如 “…… 网 络 协议 TCP/IP 等 。 B59” 亦 
为 不 正确 的 标注 。 

所 列 参 考 文献 统一 采用 小 四 号 宋体 /Times New Roman 和 1.25 倍 行距 。 

6. 附录 


附录 属于 报告 的 辅 文部 分 ， 非 必需 内 容 。 只 列 入 不 便 编 入 正文 但 与 正文 有 关 的 参考 
文件 ， 以 及 其 他 提供 查核 的 索引 、 文 献 、 图 表 、 计 算 机 程序 、 测 试 模拟 数据 集 与 测试 结 
果 、 系 统 技术 文档 、 主 要 设备 与 仪器 仪表 的 性 能 指标 和 测试 精度 等 各 类 资料 和 数据 。 但 一 
般 在 通用 手册 或 图 书 中 可 查 到 的 内 容 不 必 编 入 。 附 录 应 另 起 一 页 ， 以 “附录 和 ”形式 单独 
编 顺 序号 。 


2.3 ”课程 实验 其 他 相关 要 求 


1. 课程 实验 提交 的 资料 

完成 课程 实验 后 ， 每 名 学 生 应 提交 本 次 课程 实验 纸 质 报告 ， 并 以 班级 为 单位 刻录 包 
括 课程 实验 报告 在 内 的 相关 电子 版 的 资料 光盘 。 每 名 学 生 的 相关 电子 版 资料 ， 存 放 在 以 
“学 号 + 姓名 ”为 名 称 的 文件 夹 下 。 光 盘 中 相关 电子 版 的 资料 ， 可 以 是 源 程序 、 目 标 程序 
和 操作 手册 等 内 容 。 

2. 指导 教师 的 职责 


(1) 根据 学 科 发 展 ， 负 责 适 时 修订 教学 大 纲 内 容 。 

(2) 负责 制定 并 下 达 课 程 实验 任务 书 。 课 程 实验 任务 书 应 该 包含 课程 实验 的 题目 名 称 
和 内 容 要 求 。 

(3) 负责 课程 实验 全 程 指导 ， 包 括 课程 实验 任务 讲解 、 实 验 过 程 答疑 、 报 告 撰写 详细 
提纲 和 报告 格式 规范 化 指导 。 

(4) 负责 课程 实验 成 绩 评定 与 工作 总 结 。 


“10- 数据 库 系统 原理 及 应 用 课程 设计 与 实验 指导 


附件 2-1 课程 实验 报告 封面 格式 


x XxX 大 学 


课程 名 称 : 


专业 班级 : 
学 号 : 
姓 名 : 
指导 教师 : 
报告 日 期 : 
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附件 2-2 课程 实验 报告 正文 格式 


xxx 大 学 x xX Xx 学院 实验 报告 


系 : 专业 : 年 级 : 
姓名 : 学 号 : 实验 课程 
实验 室 号 : 实验 设备 号 : 实验 时 间 
指导 教师 : 成 绩 : 


1. 实验 名 称 
水 站 区 天光 

2. 实验 目的 和 要 求 
又 蛇 六 区 


3. 实验 原理 
xxxxx 


4. 主要 仪器 设备 (实验 用 的 软 硬 件 环境 ) 
冯 况 尖 光 议 

5. 操作 方法 与 实验 步骤 
多 区 区 允 汪 


. 实验 内 容 及 实验 数据 记录 
双关 交 六 六 


. 实验 数据 处 理 与 分 析 
XKXXKX 


. 质疑 、 建 议 、 问 题 讨论 
XXXXX 
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课程 名 称 : 数据 库 系统 原理 及 应 用 
课程 编码 : 六 六 六 六 六 

课程 类 型 .理论 + 实践 
课程 性 质 ， 必修 

总 学 时 : 64 学 时 (其 中 实验 16 学 时 ) 
总 学 分 : 4 


适用 专业 : 计算 机 科学 与 技术 、 网 络 工 程 、 软 件 工程 等 


3.1 大 纲 说 明 


1. 课程 性 质 


“数据 库 系 统 原理 及 应 用 ”是 计算 机 各 专业 的 核心 课程 之 一 ， 也 是 一 门 理论 性 和 实践 
性 都 很 强 的 课程 ， 具 有 知识 体系 完整 、 理 论 丰 富 、 实 践 性 强 、 技 术 发 展 迅速 等 特点 。 

近年 来 ， 数 据 库 技 术 不 断 发 展 、 创 新 、5 并 广泛 应 用 于 社会 各 行 各 业 。 特 别 是 随 
着 Intemet 的 发 展 与 普及 ， 基 于 网 络 和 数据 库 技术 的 信息 管理 系统 、 应 用 系统 得 到 了 飞速 
的 发 展 与 深入 广泛 的 应 用 ， 作 为 其 后 台 与 基础 的 数据 库 技术 也 在 不 断 发 展 中 被 赋予 了 新 的 
能 力 ， 成 为 发 展 最 快 、 应 用 最 广 的 技术 之 一 。 目 前 ， 绝 大 多 数 计算 机 应 用 都 需要 数据 库 技 
术 的 支撑 ， 数 据 库 已 经 成 为 计算 机 信息 系统 与 应 用 系统 的 核心 技术 和 重要 基础 。 

在 该 课程 的 教学 中 ， 不 仅 应 教会 学 生 数据 库 的 基本 知识 ， 使 学 生 能 够 正确 理解 数据 库 
的 基本 原理 ， 熟 练 掌握 数据 库 的 设计 方法 和 应 用 技术 ， 更 应 激发 学 生 对 数据 库 及 相关 知识 
的 兴趣 ， 培 养 学 生 独 立 探求 新 技术 、 新 方法 的 能 力 ， 使 其 成 为 适应 能 力 强 并 富有 创造 才能 
的 专门 人 才 。 

2. 课程 目标 

(1) 通过 本 课程 的 学 习 ， 使 学 生理 解数 据 库 系统 的 基本 原理 ， 提 高 学 生 的 理论 知识 水 
平 。 这 些 基 本 的 数据 库 理论 和 概念 包括 : 数据 模型 ， 数据库 系统 的 组 成 ， 关 系数 据 库 的 基本 
念 , 关系 代数 , SQL 语言 , 优化 技术 和 关系 数据 理论 , 数据 库 的 设计 理论 以 及 数据 保护 等 。 

(2) 通过 本 课程 的 学 习 ， 使 学 生 掌 握 基本 的 数据 库 技 术 和 方法 ， 培 养 学 生 的 实际 动手 
能 力 。 要 求学 生 能 利用 学 习 的 数据 库 原 理 知 识 和 任意 的 数据 库 管理 系统 以 及 应 用 开发 工具 
动手 开发 一 个 数据 库 应 用 系统 ， 培 养 学 生 运用 数据 库 技术 解决 问题 的 能 力 ， 激 发 他 们 在 此 
领域 中 继续 学 习 和 研究 的 兴趣 。 
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(3) 通过 本 课程 的 学 习 ， 使 学 生 了 解数 据 库 技术 的 发 展 趋势 ， 培 养 学 生 的 科研 素质 。 

3. 课程 的 基本 要 求 

了 解 计算 机 数据 管理 技术 的 发 展 过 程 及 当今 数据 库 的 新 技术 ; 掌握 数据 库 的 三 种 数据 
模型 的 特点 、 数 据 库 模型 的 三 级 模式 结构 及 二 级 映射 ， 掌握 数据 库 关 系 代 数 和 关系 数据 库 
语言 SQL 的 语法 结构 、 基 本 语句 ， 了解 关系 数据 库 管理 系统 中 查询 优化 的 重要 性 ; 了 解 关 
系数 据 理论 的 基本 概念 ; 掌握 数据 库 设计 的 阶段 划分 和 每 个 阶段 的 主要 工作 ; 掌握 规范 化 理 
论 及 其 在 数据 库 设计 中 的 作用 ， 掌 握 数 据 库 数据 的 安全 保护 ， 熟 悉数 据 库 开发 设计 全 过 程 。 




















4. 课程 基本 内 容 与 学 时 分 配 ( 表 3-1) 


表 3-1 课程 基本 内 容 与 学 时 分 配 


章 (单元 ) 内 容 实验 (上 机 ) 学 时 小 计 学 时 
结论 | | .0 .| % 


i 关系 数据 库 
= 章 ”关系 数据 库 标 准 语言 SQL 
i ”数据 库 安 全 性 
i 章 ”数据 库 完整 性 
六 章 ”关系 数据 理论 
; 章 ”数据 库 设计 
章 ”数据 库 编程 
章 关系 查询 处 理 和 查询 优化 
数据库 恢 复 技术 


Sls|is|ialao|lw|s|s 


5. 建议 教材 与 参考 书 


教材 : 
[1] 王 珊 ， 萨 师 迷 . 数据 库 系统 概论 (第 5 版 ) 北京 : 高 等 教育 出 版 社 ，2014. 
主要 参考 书 : 
[1] 施 伯乐 ， 等 . 数据 库 系统 教程 . 北京 : 高 等 教育 出 版 社 ，2003. 
[2] 丁 宝 康 ， 等 . 数据 库 原理 . 北京 : 经 济 科 学 出 版 社 ，2000. 
[3] 崔 赔 . 数据 库 系 统 及 应 用 (第 二 版 ). 北京 : 高 等 教育 出 版 社 ，2003. 
[4] 李 卓 玲 . 数据 库 原理 与 应 用 . 北京 : 电子 工业 出 版 社 ，2000. 
6. 课程 考核 方式 与 成 绩 评定 办 法 
平时 成 绩 由 平时 作业 和 实验 情况 判定 ， 期 末 考 试 采用 闭卷 笔试 方式 。 
出 勤 要 求 : 学 生 缺 勤 不 得 多 于 总 课时 的 三 分 之 一 。 教 师 可 以 根据 考勤 情况 决定 学 生 是 
否 可 以 参加 考试 、 是 否 扣 分 。 
可 按 以 下 比例 给 出 总 评 成 绩 : 平时 成 绩 (包括 实验 )20%, 考勤 10%, 期 末 考 试 70%( 笔 试 )。 


















































第 一 章 ”绪论 (6 学 时 ) 


1. 教学 目的 和 要 求 

学 习 本 章 的 重点 在 于 对 基本 概念 和 基本 知识 的 理解 ， 为 以 后 的 学 习 打 好 扎实 的 基础 。 

(1) 需要 了 解 的 : 数据 管理 技术 的 产生 和 发 展 、 数 据 库 系 统 的 特点 、 层 次 数据 模型 及 
网 状 数据 模型 的 基本 概念 、 数 据 库 系 统 的 组 成 和 DBA 的 职责 、 数 据 库 技术 的 主要 研究 领 
域 等 。 

(2) 需要 牢固 掌握 的 : 数据 、 数 据 库 、 数 据 库 管 理 系统 、 数 据 库 系统 ， 数 据 模型 的 概 
念 、 组 成 要 素 及 常用 的 数据 模型 ， 概 念 模型 的 基本 概念 及 其 主要 建 模 方法 一 一 E-R 方法 ; 
关系 数据 模型 的 相关 概念 ， 如 关系 、 属 性 、 域 、 元 组 、 主 码 、 分 量 、 关 系 模式 ， 数 据 库 系 
统 三 级 模式 和 两 级 映像 的 体系 结构 、 数 据 库 系统 的 逻辑 独立 性 和 物理 独立 性 等 。 

(3) 需要 举一反三 的 : 通过 E-R 方法 来 描述 现实 世界 的 概念 模型 。 

(4) 难点 : 数据 库 领 域 大 量 的 基本 概念 及 数据 库 系统 的 体系 结构 。 

2. 教学 基本 内 容 

数据 库 系统 概述 、 数 据 模型 、 数 据 库 系统 的 结构 、 数 据 库 系统 的 组 成 、 数 据 库 技术 的 
研究 领域 。 


第 二 章 关系 数据 库 (6 学 时 ) 


1. 教学 目的 和 要 求 

关系 模型 和 关系 数据 库 是 数据 库 系统 课程 的 重点 ， 本 章 的 关键 内 容 是 学 习 后 续 各 章 的 
基础 。 

(1) 需要 了 解 的 : 关系 数据 库 理论 产生 和 发 展 的 过 程 、 关 系数 据 库 产 品 的 发 展 、 关 系 
演算 的 概念 ， 域 关系 演算 语言 (不 包括 在 本 科教 学 大 纲 内 )、 元 组 关系 演算 语言 ALPHA。 

(2) 需要 牢固 掌握 的 ; 关系 模型 的 三 个 组 成 部 分 及 各 部 分 所 包括 的 主要 内 容 ， 关 系数 
据 结 构 及 其 形式 化 定义 ( 域 、 关 系 、 笛 卡尔 积 、 关 系 的 分 类 、 关 系 模式 、 关 系数 据 库 、 关 系 
数据 库 模 式 )， 关 系 的 三 类 完整 性 约束 。 

(3) 需要 举一反三 的 ， 关系 代数 ， 关 系 代数 中 的 各 种 运算 (包括 并 、 交 、 差 、 选 择 、 投 
影 、 连 接 、 除 及 广义 笛 卡 尔 积 等 )， 并 能 够 使 用 这 些 运算 完成 各 种 数据 操作 。 

言 完 成 对 数据 库 的 各 种 数据 操作 。 由 于 关系 代数 较为 抽象 ， 

此 在 学 习 的 过 程 中 一 定 要 结合 具体 的 实例 进行 学 习 ( 可 以 在 教材 的 基础 上 适当 补充 具体 实例 )。 

2. 教学 基本 内 容 

关系 模型 、 关 系数 据 结构 及 形式 化 定义 、 关 系 的 完整 性 、 关 系 代数 、 关 系 演算 。 

第 三 章 ”关系 数据 库 标准 语言 SQL(16 学 时 ) 


1. 教学 目的 和 要 求 
SQL 语言 是 关系 数据 库 的 标准 语言 ， 是 本 课程 的 一 个 重点 。 本 章 总 体 要 求 是 : 全 面 掌 
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握 ， 深 刻 理解 ， 熟 练 应 用 。 

(1) 需要 了 解 的 : SQL 语言 发 展 的 过 程 , 关系 数据 库 技术 和 RDBMS 产品 的 发 展 过 程 。 

(2) 需要 牢固 掌握 的 ，SQL 语言 的 特点 与 两 种 使 用 方式 、SQL 语言 与 非 关系 模型 数据 
语言 的 不 同 、 视 图 的 概念 和 作用 、SQL 语言 对 关系 数据 库 模 式 的 支持 。 

(3) 需要 举一反三 的 :熟练 而 正确 地 使 用 SQL 语言 完成 对 数据 库 的 增 、 删 、 改 、 查 操 
作 ， 特 别 是 SQL 语言 强大 的 查询 功能 。 

(4) 难点 : 使 用 SQL 语言 完成 对 数据 库 的 各 种 复杂 查询 。 

2. 教学 基本 内 容 

SQL 概述 ，SQL 的 数据 定义 、 数 据 查 询 、 数 据 更 新 ， 视 图 ， 数 据 控制 ， 嵌 入 式 SQL。 

第 四 章 “数据库 安 全 性 (4 学 时 ) 

1. 教学 目的 和 要 求 

(1) 需要 了 解 的 : 什么 是 计算 机 系统 安全 性 问题 ， 什么 是 数据 库 的 安全 性 问题 ; 统计 
数据 库 的 安全 性 问题 。 

(2) 需要 牢固 掌握 的 ， 实 现 数 据 库 安全 性 控制 的 常用 方法 和 技术 有 哪些 ， 数 据 库 中 自 
主 存 取 控制 方法 和 强制 存 取 控 制 方法 。 

(3) 需要 举一反三 的 : 使 用 SQL 语言 中 的 GRANT 和 REVOKE 语句 来 实现 自主 存 取 
控制 。 

(4) 难点 : 强制 存 取 控制 机 制 中 确定 主体 能 否 存 取 客 体 的 存 取 规则 。 

2. 教学 基本 内 容 

计算 机 的 安全 性 概论 、 统 计数 据 库 安 全 性 。 


第 五 章 数据 库 完整 性 (4 学 时 ) 


1. 教学 目的 和 要 求 

(1) 需要 了 解 的 : 什么 是 数据 库 的 完整 性 约束 和 条件， 完整 性 约束 条 件 的 分 类 ; 数据 库 
的 完整 性 概念 与 数据 库 的 安全 性 概念 的 区 别 和 联系 。 

(2) 需要 牢固 掌握 的 ， 实体 完整 性 、 参 照 完 整 性 、 用 户 定义 的 完整 性 。 

(3) 需要 举一反三 的 : 用 SQL 语言 定义 关系 模式 的 完整 性 约束 条 件 ， 包 括 定 义 每 个 模 
式 的 主 码 、 定 义 参 照 完 整 性 、 定 义 与 应 用 有 关 的 完整 性 、 完 整 性 约束 命名 子 句 、 使 用 触发 
器 定义 完整 性 。 

(4) 难点 : 关系 数据 库 管 理 系统 如 何 实现 参照 完整 性 的 策略 ， 即 当 操作 违反 实体 完整 
性 、 参 照 完 整 性 和 用 户 定义 的 完整 性 约束 条 件 时 ， 数 据 库 管 理 系统 如 何 进行 处 理 ， 以 确保 
数据 的 正确 与 有 效 。 

2. 教学 基本 内 容 

实体 完整 性 、 参 照 完 整 性 、 用 户 定义 的 完整 性 。 





























*16。 数据 库 系统 原理 及 应 用 课程 设计 与 实验 指导 


第 六 章 ”关系 数据 理论 (8 学 时 ) 

1. 教学 目的 和 要 求 

本 章 理论 性 较 强 ， 学 习 者 应 首先 从 概念 着 手 ， 搞 清关 系数 据 库 规范 化 理论 的 概念 及 其 
在 数据 库 设 计 中 的 作用 。 本 章 教学 目的 有 两 个 ， 一 是 用 更 加 形式 化 的 关系 数据 理论 来 描述 
和 研究 关系 模型 ， 二 是 利用 关系 数据 理论 指导 数据 库 设 计 。 

(1) 需要 了 解 的 : 规范 化 理论 的 重要 意义 ; 数据 库 模式 的 插入 异常 和 删除 异常 的 概念 ; 
数据 库 模式 好 和 坏 的 衡量 标准 。 

(2) 需要 牢固 掌握 的 : 关系 的 形式 化 定义 ; 数据 依赖 的 基本 概念 ; 范式 的 概念 ; 从 INF 
到 4NF 的 定义 ; 规范 化 的 含义 和 作用 。 

(3) 需要 举一反三 的 :四 个 范式 的 理解 和 应 用 ， 各 个 级 别 范式 中 存在 的 问题 和 解决 办 
法 ; 能够 根据 应 用 语义 完整 地 写 出 关系 模式 的 数据 依赖 集合 ， 并 能 根据 数据 依赖 分 析 某 一 
个 关系 模式 属于 第 几 范式 。 

(4) 难点 : 各 个 级 别 范式 的 关系 及 证 明 。 

2. 教学 基本 内 容 

函数 依赖 、 码 、 范 式 、2NF、3NF、BCNF、 多 值 依赖 、4NF、 数 据 依 赖 的 公理 系统 、 
模式 分 解 。 


























第 七 章 数据 库 设 计 (6 学 时 ) 
1. 教学 目的 和 要 求 


本 章 实用 性 较 强 ， 学 完 本 章 ， 学 习 者 应 具有 设计 简单 的 数据 库 系 统 的 能 力 。 

(1) 需要 了 解 的 : 数据 库 设 计 的 特点 ; 数据 库 物 理 设 计 的 内 容 和 评价 ;数据 库 的 实施 
和 维护 。 

(2) 需要 牢固 掌握 的 : 数据 库 设 计 的 基本 步骤 数据库 设 计 过 程 中 数据 字典 的 内 容 
数据 库 设 计 各 个 阶段 的 具体 设计 内 容 、 设 计 描述 、 设 计 方 法 等 。 

(3) 需要 举一反三 的 ，E-R 图 的 设计 ，E-R 图 向 关系 模型 的 转换 。 

(4) 难点 : 理论 和 实际 的 结合 ，E-R 图 的 设计 ， 数据 模型 的 优化 。 

2. 教学 基本 内 容 

数据 库 应 用 系统 设计 的 特点 、 方 法 和 步骤 ; 需求 分 析 ; 概念 结构 设计 ; 逻辑 结构 设计 ; 
数据 库 的 物理 设计 ; 数据 库 的 实施 和 维护 。 

第 八 章 ”数据 库 编程 (6 学 时 ) 

1. 教学 目的 和 要 求 

本 章 讲解 开发 数据 库 应 用 系统 的 各 种 编程 方法 ， 内 容 的 实践 性 较 强 ， 通 过 实践 培养 选 
择 不 同方 法 和 技术 开发 数据 库 应 用 程序 的 能 力 。 

(1) 需要 了 解 的 : SQL 编程 技术 可 以 有 效 克 服 SQL 实现 复杂 应 用 方面 的 不 足 ， 提 高 应 
系统 和 RDBMS 之 间 的 互 操作 性 。 

(2) 需要 牢固 掌握 的 : 嵌入 式 SQL 中 游标 的 概念 和 使 用 方法 ; 工 SQL 和 存储 过 程 的 基 
本 概念 、 基 本 结构 、 语 句 语法 和 用 法 。 
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(3) 需要 举一反三 的 : 能 在 实际 安装 的 RDBMS 上 通过 编程 的 方式 开发 应 用 程序 ， 完 
成 对 数据 库 的 各 类 操作 。 

(4) 难点 : 游标 的 使 用 ， 存 储 过 程 的 编写 : 应 用 程序 的 开发 。 

2. 教学 基本 内 容 

嵌入 式 SQL 中 游标 的 概念 ，SQL 的 过 程 化 、 存 储 过 程 和 自 定义 函数 。 


第 九 章 ”关系 查询 处 理 和 查询 优化 (4 学 时 ) 


1. 教学 目的 和 要 求 

本 章 进 一 步 介 绍 关系 数据 库 的 基本 概念 ， 简 单 介绍 RDBMS 查询 优化 技术 的 重要 概念 
和 实现 技术 。 

(1) 需要 了 解 的 ， 关系 系统 的 定义 和 分 类 ; 全 关系 系统 的 十 二 条 准则 。 

(2) 需要 牢固 掌握 的 ;最 小 关系 系统 、 关 系 完备 系统 、 全 关系 系统 和 关系 系统 查询 优 
化 的 概念 。 

(3) 需要 举一反三 的 : 画 出 一 个 查询 的 语法 树 以 及 优化 后 的 标准 语法 树 。 

(4) 难点 : 优化 算法 ， 包 括 代数 优化 算法 和 物理 优化 算法 。 

2. 教学 基本 内 容 

关系 系统 的 定义 、 关 系 系统 的 分 类 ; 查询 优化 的 概念 、 查 询 优化 的 一 般 准 则 ;关系 代 
数 等 价 变换 规则 及 优化 算法 。 





第 十 章 ”数据 库 恢复 技术 (4 学 时 ) 


1. 教学 目的 和 要 求 

(1) 需要 了 解 的 : 什么 是 数据 库 的 一 致 性 状态 ; 数据 库 运 行 中 可 能 产生 的 故障 类 型 及 它们 
对 数据 库 的 破坏 ， 数 据 转 储 的 概念 和 分 类 ; 什么 是 数据 库 镜 像 功 能 ， 具 有 检查 点 的 恢复 技术 。 

(2) 需要 牢固 掌握 的 : 事务 的 基本 概念 和 事务 的 ACID 性 质 ; 数据 库 恢复 的 实现 技术 ; 
日 志文 件 的 内 容 和 作用 ， 登 记 日 志文 件 所 要 遵循 的 准则 。 

(3) 需要 举一反三 的 : 恢复 的 基本 原理 ， 针 对 不 同 故障 的 恢复 的 策略 和 方法 。 

(4) 难点 : 日 志文 件 的 使 用 ， 系 统 故障 恢复 策略 。 

2. 教学 基本 内 容 

事务 的 概念 与 性 质 、 恢 复 技术 、 故 障 的 种 类 及 恢复 策略 、 检 查 点 技术 。 


3.3 ”实验 教学 大 岗 


1. 实验 项 目 设置 及 学 时 分 配 ( 表 3-2) 


表 3-2 实验 项 目 设置 及 学 时 分 配 
实验 项 目 
数据 库 和 基本 表 操作 








实验 项 目 
单 表 查询 
多 表 连 接 查 询 
恢 套 查询 与 集合 查询 
索引 与 视图 
工 SQL 程序 设计 
存储 过 程 
数据 库 的 安全 
数据 库 备 份 和 还 原 


2. 实验 内 容 
































(1) 实验 1 数据 库 和 基本 表 操作 

实验 目的 、 要 求 : 理解 和 掌握 数据 库 DDL 语言 ,前 练 地 使 用 SQL DDL 语句 创建 、 
修改 和 删除 数据 库 、 模 式 和 基本 表 。 

实验 内 容 ， 理解 和 掌握 SQL DDL 语句 的 语法 ， 特 别 是 各 种 参数 的 具体 含义 和 使 用 方 
法 ， 使 用 SQL 语句 创建 、 修 改 和 删除 数据 库 、 模 式 和 基本 表 。 掌 握 SQL 语句 常见 语法 错 


误 的 调试 方法 。 

(2) 实验 2 数据 操作 

实验 目的 、 要 求 : 熟悉 数据 库 的 数据 更 新 操作 ， 能 够 使 用 SQL 语句 对 数据 库 进行 数据 
的 插入 、 修 改 、 删 除 操作 。 

实验 内 容 : 针对 TPC-H 数据 库 设计 单元 组 插入 、 批 量 数据 插入 、 修 改 数 据 和 删除 数据 
等 SQL 语句 。 理解 和 掌握 INSERT、UPDATIE 和 DELETE 语法 结构 的 各 个 组 成 成 分 ， 结 合 
撕 套 SQL 子 查询 ， 分 别 设计 几 种 不 同形 式 的 插入 、 修 改 和 删除 数据 的 语句 ， 并 调试 成 功 。 

(3) 实验 3 单 表 查 询 

实验 目的 、 要 求 : 掌握 SQL 查询 语句 的 一 般 格式 ， 熟 练 运用 SQL 语言 实现 单 表 数 据 
基本 查询 。 

实验 内 容 : 针对 TPC-H 数据 库 设 计 单 表 查 询 , 包括 SELECT 子 句 中 “目标 列表 达 式 ”、 
WHERE 子 句 中 “条 件 表达 式 ” 的 各 种 使 用 形式 和 聚集 函数 的 使 用 。 理 解 和 掌握 SQL 查询 
语句 各 个 子 句 的 特点 和 作用 ， 按 照 SQL 程序 设计 规范 写 出 具体 的 SQL 查询 语句 ， 并 调试 
成 功 。 

【说 明 】SQL 程序 设计 规范 包含 SQL 关键 字 大 写 ， 表 名 、 属 性 名 、 存 储 过 程 名 等 标识 
符 大 小 写 混合 ，SQL 程序 书写 缩 进 排列 等 编程 规范 。 

(4) 实验 4 多 表 连 接 查询 

实验 目的 、 要 求 : 熟练 掌握 SQL 查询 语句 的 一 般 格式 , 灵活 掌握 多 表 连 接 查 询 的 使 用 。 

实验 内 容 : 针对 TPC-H 数据 库 ， 正 确 分 析 用 户 查询 要 求 ， 设 计 各 种 等 值 连接 查询 、 自 
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然 连接 查询 、 自 身 连接 查询 和 外 连接 查询 。 

(5) 实验 5 嵌 套 查询 与 集合 查询 

实验 目的 、 要 求 : 掌握 SQL 媒 套 查询 和 集合 查询 等 各 种 高 级 查询 的 设计 方法 等 。 

实验 内 容 : 针对 TPC-H 数据 库 ， 正 确 分 析 用 户 查 询 要 求 ， 设 计 各 种 嵌 套 查询 和 集合 查 
询 。 理 解 掌握 相关 子 查询 与 不 相关 子 查询 。 

(6) 实验 6 索引 与 视图 

实验 目的 、 要 求 : 掌握 索引 设计 原则 和 技巧 ， 能够 创建 合适 的 索引 以 提高 数据 库 查 询 、 
统计 分 析 效 率 。 熟 悉 SQL 语言 有 关 视 图 的 操作 ， 能 够 熟练 使 用 SQL 语句 来 创建 需要 的 视 
图 ， 并 能 使 用 所 创建 的 视图 实现 数据 管理 。 

实验 内 容 : 针对 给 定 的 数据 库 模式 和 具体 应 用 需求 ， 创 建 、 修 改 和 删除 索引 、 视 图 。 
理解 和 掌握 视图 消解 执行 原理 ， 掌 握 可 更 新 视图 和 不 可 更 新 视图 的 区 别 。 

(7) 实验 7 TSQL 程序 设计 

实验 目的 、 要 求 : 掌握 数据 库 工 SQL 编程 语言 的 基础 知识 ， 以 及 工 SQL 程序 设计 的 
控制 结构 、 自 定义 函数 和 程序 设计 方法 。 

实验 内 容 : SQL 变量 的 定义 、 赋 值 及 输出 ， 流 程控 制 语句 的 使 用 。 掌 握 工 SQL 编程 规 
范 ， 规 范 设计 自 定义 函数 。 

(8) 实验 8 存储 过 程 

实验 目的 、 要 求 : 掌握 数据 库 T-SQL 编程 语言 ， 以 及 数据 库存 储 过 程 的 设计 和 使 用 
方法 。 

实验 内 容 ， 存储 过 程 定义 ， 存 储 过 程 运行 ， 存 储 过 程 更 名 ， 存 储 过 程 删 除 ， 存 储 过 程 
的 参数 传递 ， 规 范 设计 存储 过 程 。 

(9) 实验 9 触发 器 

实验 目的 、 要 求 : 掌握 数据 库 触 发 器 的 设计 和 使 用 方法 。 

实验 内 容 ; 定义 DDL 触发 器 和 DML 触发 器 。 能 够 理解 不 同类 型 触发 器 的 执行 原理 ， 
验证 触发 器 的 有 效 性 。 

(10) 实验 10 数据库 的 安全 

实验 目的 、 要 求 : 掌握 自主 存 取 控制 权限 的 定义 和 维护 方法 。 

实验 内 容 : 定义 用 户 、 角 色 ， 分 配 权限 给 用 户 、 角 色 ， 回 收 权限 ， 以 相应 的 用 户 名 
登录 数据 库 验 证 权限 分 配 是 否 正确 。 选 择 一 个 应 用 场景 ， 使 用 自主 存 取 控 制 机 制 设 计 权 
限 分 配 。 

(11) 实验 11 数据 库 备 份 和 还 原 

实验 目的 、 要 求 : 掌握 数据 库 数 据 转 储备 份 、 逻 辑 恢 复 和 物理 恢复 的 方法 。 

实验 内 容 : 了 解数 据 转 储备 份 和 恢复 的 概念 。 学 习 使 用 SQL Server 数据 库 进 行 数据 备 
份 与 恢复 的 方法 。 利 用 数据 库 管 理 系统 提供 的 备份 工具 ， 实 现 各 种 数据 库 备 份 策略 。 


3. 考核 与 报告 
在 考核 方式 上 ， 改 变 传统 可 





















































核 标准 来 对 学 生 进 行 实验 过 程 监控 和 考核 ， 着 力 在 新 知识 、 新 技术 获取 及 动手 能 力 方面 。 

实验 总 成 绩 由 实验 指导 教师 结合 学 生 的 平时 成 绩 和 考试 成 绩 给 出 。 在 平时 成 绩 考核 
时 ， 实 行 教 师 对 学 生 的 过 程 评价 和 实验 报告 评价 相 结合 ， 对 学 生 实验 过 程 进行 综合 考核 
评定 。 

具体 评分 标准 如 下 : 

实验 总 成 绩 (100 % )- 实 验 平时 成 绩 (4096)+ 实 验 考试 成 绩 (609%) 

其 中 : 

实验 平时 成 绩 = 教 师 对 学 生 的 过 程 评价 (40%)+ 实 验 报告 评价 (60%) 

















制定 /修订 人 : Xx Xx 
审定 人 : XXX 

批准 人 : XXX 

制定 /修订 时 间 : X XxX 年 X XX 月 
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实验 1 数据 库 和 基本 表 操 作 


一 、 实 验 目的 

熟悉 SQL Server 2012 系统 环境 ， 了 解 SQL Server 基本 管理 工具 、 实 用 程序 的 使 用 。 
掌握 利用 对 象 资源 管理 器 和 Transact-SQL 语句 进行 数据 库 及 基本 表 的 定义 、 修 改 和 删除 。 
掌握 主 码 、 外 码 及 约束 的 创建 和 应 用 。 
二 、 实 验 学 时 

2 学 时 。 
三 、 实 验 内 容 

(1) 使 用 对 象 资源 管理 器 和 Transact-SQL 语句 创建 数据 库 。 

(2) 使 用 对 象 资源 管理 器 和 Transact-SQL 语句 创建 基本 表 ， 定 义 表 的 约束 。 

(3) 使 用 对 象 资源 管理 器 和 Transact-SQL 语句 修改 、 删 除 基本 表 。 
四 、 预 备 知识 

(1) SQL 全 称 为 Stuctured Query Language( 结 构 化 查询 语言 )， 由 Boyce 和 Chamberlin 
于 1974 年 提出 .SQL 语言 结构 简洁 , 功能 强大 , 简单 易学 。 SQL 语言 集 数 据 定义 (Data Definition)、 
数据 操作 (Data Manipulation) 和 数据 控制 (Data Control) 功 能 于 一 体 ， 充 分 体现 了 关系 数据 
库 语言 的 特点 和 优点 。 

(2) SQL 语言 使 用 CREATE DATABASE 语句 定义 数据 库 ， 基 本 格式 如 下 : 




















CREATE DATABASE database_ name 
[ON [PRIMARY] 
([NAME = logical file name,] 
FILENAME ='os_fle_name' 
[,SIZE = size] 
[MAXSIZE = {max_sizelUNLIMITED}] 
LFILEGROWTH = growth_increment])[, ..n] 
<filegroup>::=FILEGROUP filegroup_ name <filespec>[,.…n] 
LOG ON 
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(NAME = logical file name,FILENAME =os_fle name' 
SIZE = size, 
MAXSIZE = {max _size | UNLIMITED}. 
FILEGROWTH = growth increment )]: 


(3) SQL 语言 使 用 CREATE TABLE 语句 定义 基本 表 ， 基 本 格式 如 下 : 

















CREATE TABLE 《 表 名 》(< 列 名 > “数据 类 型 >[ 列 级 完整 性 约束 条 件 ] 
[, < 列 名 > < 数据 类 型 >[ 列 级 完整 性 约束 条 件 ]] 
[, < 表 级 完整 性 约束 条 件 >]); 
. 列 级 完 胃 性 约束 条 件 : 涉及 相应 属性 列 的 完整 性 约束 条 件 。 
e 表 级 完整 性 约束 条 件 : 涉及 一 个 或 多 个 属性 列 的 完整 性 约束 条 件 。 
(4) 定义 基本 表 时 必须 对 表 的 完整 性 进行 定义 ， 常 用 的 完整 性 约束 如 下 。 
e。 PRIMARY KEY: 主 码 ， 用 于 定义 实体 完整 性 。 利 用 表 中 一 列 或 多 列 来 唯一 标识 一 
行 数据 ， 确 保 对 应 的 数据 列 不 为 定 ， 且 数据 不 重复 。 
e FOREIGN KEY: 外 人 码 ， 用 于 定义 参照 完整 性 ， 主 要 用 来 维护 两 个 表 之 间 的 数据 一 
e NOT NULL: 列 值 非 空 。 
e UNIQUE: 列 值 唯一 ， 主 要 用 于 约束 主 码 外 的 数据 列 的 唯一 性 。 
e CHECK: 检查 列 值 是 否 满足 一 个 条 件 表达 式 。 
e DEFAULT: 列 值 的 默认 值 ， 处 理 用 户 不 包含 全 部 数据 列 的 数据 插入 。 
(5) SQL 语言 使 用 ALTER TABLE 语句 修改 基本 表 ， 基 本 格式 如 下 : 
ALTER TABLE < 表 名 > 

[ADD [COLUMN]< 新 列 名 >< 数 据 类 型 >[ 完 整 性 约束 ]] 

[ADD< 表 级 完整 性 约束 >] 

[DROP[COLUMN] < 列 名 >[CASCADE |RESTRICT]] 

[DROP CONSTRAINT< 完 整 性 约束 名 >[CASCADE |RESTRICT]] 

[ALTER COLUMN《 列 名 >< 数 据 类 型 >]; 


(6) SQL 语言 使 用 DROP TABLE 语句 删除 基本 表 ， 基 本 格式 如 下 : 


DROP TABLE 《 表 名 > [CASCADE |RESTRICT]]; 


五 、 实 验 步骤 


设 有 学 生 -课程 数据 库 StudScore DB， 数 据 库 中 包含 4 个 基本 表 ， 每 个 表 中 有 若干 数 
据 记 录 ， 如 表 4-1 一 表 4-8 所 示 。 


表 4-1 系 表 (Department) 结 构 













字段 名 称 | 数据 类 型 字段 说 明 
Dno | CHAR 系 编号 








2 站 


Dname 系 名 称 
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表 4-2 系 表 (Department) 记 录 











Dno Dname 
CS 计算 机 系 
MA 数学 系 

IS 信息 工程 系 





表 4-3 学 生 表 (Student) 结 构 








字段 长 度 字段 说 明 





是 否 为 空 

















| | | 学 5 
Sname | VARCHAR | | 姓名 
Ssex | CHAR | 默认 为 男 | 性 别 
sae | [ew 





系 编号 











Sno Dno 
201215121 Cs 
201215122 Cs 
201215123 MA 


20121525 | 垃 | IS 
201331001 MM | 男 | mm | CS 
201M39001 | 区 | 女 | 1 | cs 





表 4-5 hk 寺 构 





字段 说 明 
课程 编号 
课程 名 称 
选修 课 呈 
学 分 










字段 名 称 


Cno 






Cname 





Cpno 
Ceredit 









Cpno Cceredit 





数据 库 
数学 
信息 系统 
操作 系统 
数据 结构 
数据 处 理 
C 语言 























DB _Design 
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表 4-7 成 绩 表 (SC) 结 构 








字段 说 明 








Sno 学 号 
Cno 课程 编号 





成 绩 











Sno Grade 
201215121 92 
201215121 85 
201215121 88 
201215122 90 
201215122 80 
201331001 55 
201331001 90 
201331001 80 
201439001 69 
201215125 NULL 





1. 利用 对 象 资源 管理 器 创建 数据 库 


(1) 启动 SQL Server Management Studio， 进 入 SQL Server 2012 对 象 资源 管理 器 。 

(2) 选中 需要 在 其 上 创建 数据 库 的 服务 器 ， 单 击 前 面 的 + 号 ， 使 其 展示 为 树 状 目录 。 

(3) 选中 “数据 库 ?， 右 击 ， 选 择 “新 建 数据 库 ” 如 图 4-1 所 示 。 随 后 在 “新 建 数据 
库 ” 对 话 框 的 “常规 ”选项 卡 中 ， 在 “数据 库 名称 ” 文 本 框 中 输入 正确 的 数据 库 名 称 (如 
StudScore DB)， 设 置 数据 文 件 和 日 志文 件 的 名 称 、 位 置 、 文 件 大 小 、 增 长 方式 和 路 径 等 信 
息 ， 如 图 4-2 所 示 。 


朗 件 加。 堪 坟 加、 这 看 调 二 工具 中 记 口 中 社区 天 肋 吕 
朋 新 半 喜 淘 gD | Dy | EA 


和 连接" 都 才 a 了 国 当 
SB CompuTERWYSQLSERYIR2008 (QL Server 10. 
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图 4-1 在 快捷 菜单 中 选择 “新 建 数 据 库 ” 
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图 4-2 “新 建 数据 库 ” 对 话 框 


(4) 单 击 “ 确 定 ”按钮 ， 在 对 象 资源 管理 器 “数据 库 ”目录 下 显示 新 创建 的 数据 库 ， 如 
图 4-3 所 示 。 
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图 4-3 成 功 新 建 数 据 库 


2. 利用 Transact-SQL 语句 创建 数据 库 


(1) 单 击 SQL Server Management Studio 工具 栏 上 的 “新 建 查询 ”按钮 ， 弹 出 一 个 查询 
窗口 。 
(2) 在 查询 窗口 中 输入 创建 数据 库 的 TransactSQL 语句 ， 代 码 如 下 : 


CREAIE DATABASE StudScore DB 
ON PRIMARY 
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(NAME= 'StudScore DB _ data'FILENAME='E:\sjk2018\ StudScore DB.mdf ) 
LOG ON 
(NAME= 'StudScore DB _log',FILENAME='E:\sjk2018\ StudScore DB.ldf ); 
【 注 】 需 先 在 E 盘 上 建立 一 个 文件 夹 (例如 : Exsjk2018)， 数 据 库 文件 保存 到 该 文件 夹 中 。 
(3) 单 击 工具 栏 上 的 “执行 ”按钮 (或 按 下 5 键 )， 完 成 数据 库 创建 ， 如 图 4-4 所 示 。 


SQLQueyl sql -L621505\SQLSEVER master (1G21505Administrator (52))" - Microsoft SQL Server Management Studio..| 








"ddameey DDDDIH 和 | | 


























[maser 了 1 Fo RDO av 阅 3 皇 | 时 | 区 | 
| 如 如 日 了 下 吧 =CREATE DATAEASE 5rud5Core_ID 
与 二 EL 和 ( WAME= "Srudscore_DE_data’, FILENANE=" E: \sjx2018\ StudScore_DB.naf ) 
习 国 BE 年 oc oR 
四 国 系统 数 丘 车 ( NANE= "Stud3core_DD_log’ ,FILENANS="E;\sjk2018\ 3tuiscore_ID,1dr” ) 同 
加 国 数 所 库 快 四 





回国 ReporServer$sQLSEVER 
回国 ReperServer$SQLSEVERTem 
田力 sudscore pe 





本 加 Alwayson 高 可 用 性 
也 加 和 





加 加 Integration Services 目 好 


七 SQL Server 全 (村 有 fg XP) 
Dow - 








4 盏 | 














图 4-4 利用 Transact-SQL 语句 新 建 数据 库 
(4) 在 “对 象 资源 管理 器 ” 窗 格 中 单 击 “刷新 ”按钮 ， 即 可 看 到 StudScore_DB 数据 库 。 
3. 利用 对 象 资源 管理 器 定义 、 修 改 、 删 除 基本 表 


(1) 在 对 象 资源 管理 器 中 ， 展 开 左 窗 格 中 树 状 结构 上 的 “数据 库 ” 节 点 。 
(2) 展开 新 建 的 数据 库 StudScore DB， 选 择 “ 表 ”， 右 击 ， 选 择 “ 新 建 表 ”， 如 图 4-5 
所 示 。 
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图 4-5 在 快捷 菜单 中 选择 “新 建 表 ” 
(3) 在 打开 的 设计 表 窗 格 中 ， 对 表 的 内 容 进 行 定义 。 内 容 如 下 : 输入 列 名 ， 列 名 在 表 
中 必须 唯一 , 列 的 命名 规则 必须 遵守 SQL Server 2012 数据 库 对 象 的 命名 规则 ; 选择 正确 的 
数据 类 型 、 数 据 长 度 和 精度 ; 设置 表格 的 完整 性 约束 (PRIMARY KEY、FOREIGN KEY、 
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NOTNULL、UNIQUE、CHECK、DEFAULT)。 定 义 完 毕 后 ， 单 击 工具 栏 的 “保存 ”按钮 ， 
然后 输入 表 名 ， 单 击 “ 确 定 ” 按 钮 ， 在 左 侧 的 对 象 资源 管理 器 中 将 显示 定义 好 的 数据 表 。 





图 4-6 定义 Department 基本 表 


(4) 基本 表 定 义 完毕 后 ， 如 需 对 其 结构 进行 修改 ， 首 先 在 对 象 资源 管理 器 中 找到 该 基 
本 表 ， 选中 后 右 击 ,在 弹出 的 菜单 中 选择 “设计 表 ”， 然 后 在 中 间 的 窗 格 中 就 可 对 原 有 内 容 
进行 修改 。 

(5) 如 需 删除 基 本 表 ， 在 对 象 资源 管理 器 中 找到 该 基本 表 ， 选 中 后 右 击 ， 在 弹出 的 菜 
单 中 选择 “删除 ”， 即 可 完成 删除 操作 (如 果 表 中 存在 参照 关系 ， 可 能 导致 删除 操作 失败 )。 

【 注 】 在 对 象 资源 管理 器 中 设置 数据 完整 性 约束 ， 有 具体 操作 如 下 。 

@ 设置 PRIMARYKEY 约束 。 

选择 要 设置 主 码 的 属性 列 (如 果 是 多 列 需 同时 选中 )， 右 击 ， 从 弹出 的 快捷 菜单 中 选择 
“设置 主键 ”命令 。 也 可 以 选中 要 建立 主 码 的 列 后 ， 直 接 单 击 工具 栏 上 的 而 | 按钮 。 操 作 完 
毕 后 ,在 主 码 的 列 旁 会 出 现 一 个 小 钥匙 形 的 标志 。Department 表 中 主 码 Dno 的 设置 ， 如 图 
4-7 所 示 。 








到 名 至 闯关 型 允许 Null 值 有 数 二 类 型 允许 Null 值 
[bj one 和 ——— 人 eo— me harG) Ein 
ES 六 手 和 到 (MV) Da varchar(20) 日 
1 eR(N) 加 
23 关系 H- 


图 4-7 设置 PRIMARY KEY 约束 


@ 设置 UNIQUE 约束 。 

a. 选择 要 设置 唯一 约束 的 属性 列 ， 右 击 ， 从 弹出 的 快捷 菜单 中 选择 “索引 / 键 ”命令 。 

b. 在 弹出 的 对 话 框 中 ， 单 击 “ 添 加 ”按钮 ， 然 后 在 右 侧 窗 格 “ 常 规 ” 的 “类 型 ”下 拉 
框 中 选择 “唯一 键 ”， 单 击 “ 列 ” 右 侧 的 加 按钮 ， 在 弹出 的 对 话 框 中 选择 要 建立 唯一 约束 
的 属性 列 ， 单 击 “ 确 定 ” 按 钮 。 
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c. 在 右 侧 窗 格 “ 标 识 ” 的 “名 称 ” 中 ， 对 唯一 性 约束 命名 。 
d. 关闭 并 保存 设置 。Department 表 中 Dname 唯一 性 约束 设置 如 图 4-8 所 示 。 
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图 4-8 设置 UNIQUE 约束 


@ 设置 FOREIGN KEY 约束 。 

a. 选择 要 设置 外 码 约束 的 属性 列 ， 右 击 ， 从 弹出 的 快捷 菜单 中 选择 “关系 ”命令 。 

b. 在 弹出 的 对 话 框 中 ， 单 击 “ 添 加 ”按钮 ， 然 后 在 右 侧 窗 格 “ 常 规 ” 中 ， 单 击 “ 表 和 
列 规范 ” 右 侧 的 回 按钮 。 

c. 在 弹出 的 对 话 框 中 进行 外 码 设置 。 在 “关系 名 ”文本 框 中 输入 外 码 约束 名 ; 在 “ 主 
键 表 ”下 拉 框 中 选择 主 表 名 及 主 表 主 码 ， 在 “外 键 表 ”下 拉 框 中 选择 从 表 名 及 要 设置 为 外 


码 的 属性 列 。 
d. 确定 、 关 闭 并 保存 设置 。Student 表 中 Dno 设置 为 外 码 ， 如 图 4-9 所 示 。 





图 4-9 设置 FOREIGN KEY 约束 


@ 设置 DEFAULT 约束 。 

a. 选择 要 设置 DEFAULT 约束 的 属性 列 。 

b. 在 下 方 “ 属 性 列 ” 对 话 框 中 ， 在 “默认 值 或 绑 定 ”文本 框 中 输入 相应 的 默认 值 ， 然 
后 保存 。Student 表 中 ，Ssex 属性 列 设置 默认 值 为 “ 男 ”， 操 作 如 图 4-10 所 示 。 
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图 4-10 设置 DEFAUIT 约束 


回 设置 CHECK 约束 。 

a. 选择 要 设置 CHECK 约束 的 属性 列 ， 右 击 ， 从 弹出 的 快捷 菜单 中 选择 “CHECK 约 
东 ” 命 令 。 

b. 在 弹出 的 对 话 框 中 ， 单 击 “ 添 加 ”按钮 ， 在 右 侧 窗 格 “常规 ”中 ， 单 击 “ 表 达 式 ” 
右 侧 的 [按钮 。 

c. 在 弹出 的 对 话 框 中 输入 CHECK 约束 表达 式 。 

d. 确定 、 关 闭 并 保存 设置 。Student 表 中 Sage 设置 [15,30] 的 CHECK 约束 ， 操 作 如 
图 4-11 所 示 。 
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图 4-11 设置 CHECK 约束 
4. 利用 Transact-SQL 语句 定义 、 修 改 、 删 除 基本 表 
(1) 定义 基本 表 : 系 表 Department、 学 生 表 Student、 课 程 表 Course 和 成 绩 表 SC， 各 
基本 表 的 具体 结构 和 约束 如 表 4-1、 表 4-3、 表 4-5 和 表 4-7 所 示 。 
@ 系 表 Department 
CREATE TABLE Department 
(Dno CHAR(2) PRIMARY KEY, 
Dname VARCHAR(20) UNIQUE 
); 
@ 学 生 表 Student 
CREATE TABLE Student 
(Sno CHAR(9) PRIMARY KEY. 
Sname VARCHAR(20) NOT NULL., 
Ssex CHAR(2) DEFAULT ' 男 ' CHECK(Ssex in( 男 " 女 9)， 
Sage SMALLINT CHECK(Sage between 15 and 30), 
Dno CHAR(2) FOREIGN KEY REFERENCES Department(Dno) 
); 
@ 课程 表 Course 
CREATE TABLE Course 
( Cno CHAR(4) PRIMARY KEY 
Cname VARCHAR(40) NOT NULL., 
Cpno CHAR(4) FOREIGN KEY REFERENCES Course(Cno)， 
Ceredit SMALLINT 
» 


“30。 数据 库 系统 原理 及 应 用 课程 设计 与 实验 指导 


@ 成 绩 表 SC 
CREATE TABLE SC 
( Sno CHAR(9) NOTNULL， 
Cno CHAR(4) NOT NULL., 
Grade SMALLINT CHECK(Grade BETWEEN 0 AND 100), 
PRIMARY KEY(Sno,Cno), 
FOREIGN KEY (Sno) REFERENCES Student(Sno), 
FOREIGN KEY (Cno) REFERENCES Course(Cno) 
); 
【 注 】 在 定义 有 外 码 约束 的 基本 表 时 ， 必 须 先 定义 主 表 ， 不 能 颠倒 次 序 ， 否 则 容易 出 
错 。 例 如 ， 在 定义 学 生 表 Student 时 ， 必 须 先 定义 系 表 Department; 在 定义 成 绩 表 SC 时 
必须 先 定 义学 生 表 Student 和 课程 表 Course。 
(2) 修改 、 删 除 基本 表 。 
@ 向 基本 表 Student 中 增加 “入 学 时 间 ” 属 性 列 ， 其 属性 名 为 S_entrance， 数 据 类 型 
为 日 期 型 。 
ALTER TABLE Student ADD S_entrance DAIE; 
@ 将 Student 表 中 Sage( 年 龄 ) 的 数据 类 型 改 为 NT 型 。 
ALTER TABLE Student ALTER COLUMN Sage INT: 
@ 增加 课程 名 称 必须 取 唯一 值 的 约束 条 件 。 
ALIER TABLE Course ADD UNIQUE(Cname); 
@ 将 Student 表 的 Ssex 列 允 许 空 值 的 属性 更 改 为 不 允许 为 空 值 。 
ALTER TABLE Student ALTER COLUMN Ssex CHAR(2) NOT NULL: 
@ 删除 Student 表 中 的 S_entrance 列 。 
ALTER TABLE Student DROP COLUMN S_entrance; 
@ 删除 Smdent 表 。 
DROP TABLE Student: 
【 注 】 由 于 主键 、 外 键 约束 ， 要 先 删 除 SC 表 ， 才 能 再 删除 Stadent 表 。 此 表 删 除 后 ， 
请 立即 重新 将 其 建立 起 来 ， 以 便 后 面 的 例子 使 用 。 


六 、 实 验 报告 要 求 

实验 报告 中 简单 描述 实验 步 又， 详细 写 明 建 库 及 建 表 的 代码 ， 并 以 截图 的 形式 显示 操 
作 是 否 成 功 。 
七 、 思 考题 


(1) 如 果 在 创建 关系 数据 库 基本 表 时 ， 未 创建 完整 性 约束 条 件 ， 对 于 数据 库 会 有 何 影响 ? 
(2) 在 定义 外 码 约束 时 ， 如 果 主 表 主 码 的 数据 类 型 与 从 表 外 码 的 数据 类 型 不 一 致 ， 以 
哪 一 个 为 准 ? 
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实验 2 数据 操作 


一 、 实 验 目的 
掌握 利用 对 象 资源 管理 器 和 Transact-SQL 语句 两 种 方法 对 基本 表 进 行 插入 、 修 改 和 删 
除数 据 操作 。 
二 、 实 验 学 时 
1 学 时 。 
三 、 实 验 内 容 
(1) 使 用 对 象 资源 管理 器 对 基本 表 进 行 插入 、 修 改 和 删除 数据 操作 。 
(2) 使 用 Transact-SQL 语句 对 基本 表 进 行 插入 、 修 改 和 删除 数据 操作 。 
四 、 预 备 知识 
(1) SQL 的 数据 插入 语句 INSERT 通常 有 两 种 形式 。 
插入 单个 元 组 ， 语 句 格 式 如 下 : 
INSERT INTO < 表 名 >[(< 属 性 列 1>L< 属 性 列 2>]...)] 
VALUES (< 常量 1>[.< 常 量 2>]...); 
多 记录 插入 一 一 将 SELECT 语句 的 查询 结果 插入 数据 表 ， 语 句 格式 如 下 


INSERT INTO < 表 名 >[(< 属 性 列 1>[,< 属 性 列 2>]..….)】] 
子 查询 ; 

(2) 数据 修改 操作 UPDATE 语句 一 般 格式 如 下 : 
UPDATE < 表 名 > 


SET < 列 名 >= < 表达 式 >[,< 列 名 >= < 表达 式 >].… 
[WHERE < 条 件 >]; 


(3) 数据 删除 操作 DELETE 语句 一 般 格 式 如 下 : 


DELETE FROM < 表 名 > 
[WHERE < 条 件 >]; 





五 、 实 验 步骤 


1. 利用 对 象 资源 管理 器 对 基本 表 进 行 数 据 增 、 删 、 改 操作 
(1) 在 对 象 资源 管理 器 的 树 状 目录 中 ， 展 开 要 进行 操作 的 数据 库 ， 并 展开 该 数据 库 下 
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的 “ 表 ” 选择 要 插入 数据 的 基本 表 ， 右 击 ， 在 弹出 的 菜单 中 选择 “编辑 前 200 行 ”打开 插 


入 数据 窗 格 ， 如 图 4-12 所 示 。 
(2) 在 数据 编辑 窗 格 中 ， 在 记录 的 尾部 输入 要 插入 的 数据 ， 输 入 完毕 单 击 工具 栏 上 的 
“执行 ”按钮 国 . 在 系 表 Department 中 插入 数据 操作 ， 如 图 4-13 所 示 。 
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(3) 修改 数据 时 ， 用 插入 数据 相同 的 方法 打开 数据 编辑 窗 格 ， 在 编辑 窗 格 中 对 需 修改 
的 数据 直接 修改 ， 用 新 值 奉 换 原 值 。 修 改 完毕 单 击 工 具 栏 上 的 “执行 ”按钮 。 

(4) 删除 数据 时 ， 用 插入 数据 相同 的 方法 打开 数据 编辑 窗 格 ， 在 编辑 窗 格 中 选 定 将 要 
删除 的 行 ， 右 击 ， 在 弹出 的 快捷 菜单 中 选择 “删除 ”命令 ， 在 打开 的 删除 对 话 框 中 选择 “是 ”， 
即 可 完成 数据 删除 。 

2. 利用 Transact-SQL 语句 对 基本 表 进 行 数据 增 、 删 、 改 操作 

【 注 】 在 进行 此 部 分 操作 前 ， 请 先 完成 对 表 4-2、 表 4-4、 表 4-6 和 表 4-8 中 相关 数据 的 
录入 ， 耕 则 操作 可 能 出 错 。 

(1) 将 一 个 新 学 生 记 录 ( 学 号 ，201215124; 姓名 ， 陈 冬 ; 性别 ， 男 ， 所 在 系 号 ，IS; 年 
龄 ，18 岁 ) 插 入 Student 表 中 。 

【方法 一 】 

INSERT INTO Student 
VALUES(C201215124'. 陈 冬 " 男 ,18.TS); 
【方法 三 了 
INSERT INTO Student(Sno,Sname,Ssex,Dno,Sage) 
VALUES(201215124'. 陈 冬 " 男 , TS',18); 
(2) 向 SC 表 中 插入 一 条 记录 (201215124'"1.77) 
INSERTINTO SCVALUES(201215124.1.77); 
(3) 将 Student 表 中 信息 工程 系 (IS) 学 生 的 记录 的 学 号 、 姓 名 插入 新 表 StudentBAK1 中 。 
(插入 多 个 元 组 ) 


USE StudScore DB 
CREATE TABLE StudentBAK1 
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(Sno CHAR(9) PRIMARY KEY., 
Sname VARCHAR(8) NOT NULL 
); 
INSERT INTO StudentBAK1 
SELECT Sno,Sname FROM Student WHERE Dno='IS': 


(4) 将 学 号 为 201215121 的 学 生 的 年 龄 改 为 21 岁 。( 修 改 满 足 条 件 的 一 个 元 组 的 属性 值 ) 


UPDATE Student 
SET Sage=21 
WHERE Sno='201215121'; 


(5) 将 所 有 学 生 的 年 龄 增加 2 岁 。( 修 改 满足 条 件 的 多 个 元 组 的 属性 值 ) 
UPDATE Student SET Sage=Sage+2; 
(6) 将 姓名 为 “王立 ”的 学 生 的 性 别 改 为 “ 女 ”， 年 龄 改 为 18 岁 。 
UPDATE Student 
SET Ssex=' 女 ',Sage=18 
WHERE Sname=' 王 立 ':; 
(7) 将 选修 了 “数据 库 ” 的 学 生成 绩 加 2 分 。 
UPDATE SC 
SET Grade=Grade+2 
WHERE Cno=(SELECT Cno FROM Course WHERE Cname=' 数 据 库 )); 
(8) 将 计算 机 系 (CS) 所 有 学 生 的 成 绩 置 零 。 
由 于 学 生 所 在 系 的 信息 在 Student 表 中 ， 而 学 习 成 绩 在 SC 表 中 ,因此 可 以 将 SELECT 
子 查询 作为 WHERE 子 句 的 条 件 表达 式 。 
UPDATE SC 
SET Grade=0 
WHERE 'CS= 
(SELECT Dno 
FROM Student 
WHERE StudentSno=SC.Sno 
» 
(9) 删除 学 号 为 201215128 的 学 生 记 录 。( 删 除 一 个 元 组 ) 
DELETE FROM Student 
WHERE Sno='201215128' 


(10) 删除 所 有 学 生 的 选课 记录 。( 删 除 多 个 元 组 ) 
DELEIE FROM SC: 
(11) 删除 计算 机 系 (CS) 所 有 学 生 的 选课 记录 。 


DELETE FROM SC 
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WHERE 'CS= 
(SELECT Dno 
FROM Student 
WHERE Student.Sno=SC.Sno 


Bk 
六 、 实 验 报告 要 求 
(1) 实验 报告 必须 给 出 实现 的 SQL 语句 ， 并 对 SQL 语句 执行 前 后 各 个 基本 表 的 数据 


进行 分 析 ， 验 证 SQL 命令 的 正确 性 。 
(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 


七 、 思 考题 


(1) 如 果 在 实验 1 中 ， 没 有 定义 数据 完整 性 约束 条 件 ， 则 在 数据 录入 或 删除 过 程 中 会 
对 数据 库 造成 什么 影响 ? 

(2) 数据 库 中 一 般 不 允许 更 改 主 码 数 据 ， 如 果 需 要 更 改 主 码 数据 时 ， 怎 样 处 理 ? 

(3) 可 以 先 在 Student 表 中 删除 学 生 “ 刘 勇 ” 的 记录 ， 然 后 再 删除 SC 中 的 相应 的 记录 
吗 ? 会 出 现 什 么 异常 情况 ? 为 什么 会 出 现 这 些 异 常情 况 ? 


附 : 表 4-2、 表 4-4、 表 4-6 和 表 4-8 基础 数据 插入 语句 代码 。 


INSERT INTO Department VALUES('CS',' 计 算 机 系 "); 
INSERT INTO Department VALUESCMA' 数 学 系 ); 
INSERT INTO Department VALUES(IS', 信 息 工 程 系 "); 





INSERT INTO Student VALUES(201215121',' 刘 勇 ' 男 ',20,'CS); 
INSERT INTO Student VALUES(201215122',' 李 展 ' 女 ,19,'CS); 
INSERT INTO Student VALUES(201215123", 张 敏 ' 女 ',18,MA'): 
INSERT INTO Student VALUES(201215125',' 王 立 ', 男 ',19,IS"); 
INSERT INTO Student VALUES(C201331001" 欧 阳 小 野 '" 男 ,17,CS)); 
INSERT INTO Student VALUES(201439001"" 刘 莉 , 女 ,16.CS)); 





INSERT INTO Course VALUES(2', 数 学 'NULL,2): 
INSERT INTO Course VALUES(6',' 数 据 处 理 'NULL.2); 
INSERT INTO Course VALUES(7'C 语言 .6,4); 
INSERT INTO Course VALUES('5', 数 据 结构 ,7,4); 
INSERT INTO Course VALUES(C1' 数 据 库 '"5.4); 
INSERT INTO Course VALUES(3'"" 信 息 系统 "1.4); 
INSERT INTO Course VALUES(8"DB_Design'.1.2): 
INSERT INTO Course VALUES(4', 操 作 系统 "6.3): 

(此 处 因 有 外 码 约束 ， 插 入 时 注意 顺序 ) 
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INSERT INTO SC VALUES(201215121',"1',92); 
INSERT INTO SC VALUES(C201215121'.2,85): 
INSERT INTO SC VALUES(201215121','3',88); 
INSERT INTO SC VALUES(201215122','2',90); 
INSERT INTO SC VALUES(201215122','3',80); 
INSERT INTO SC VALUES(201331001',"1',55):; 
INSERT INTO SC VALUES(201331001",'2',90); 
INSERT INTO SC VALUES(201331001','3',80): 
INSERT INTO SC VALUES('201439001","1',69); 
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INSERT INTO SC VALUES(201215125'"1'NULL); 
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实验 3 单 表 查询 


一 、 实 验 目 的 

掌握 SQL Server 2012 查询 窗口 的 使 用 方法 ， 加 深 对 SQL 查询 语句 的 理解 。 熟 练 掌握 
SQL 查询 语句 的 一 般 格式 。 灵 活 掌 握 SELECT 子 句 中 “目标 列表 达 式 ”WHERE 子 句 中 
“条 件 表 达 式 ”的 各 种 使 用 形式 和 聚集 函数 的 一 般 格 式 。 


二 、 实 验 学 时 
2 学 时 。 
三 、 实 验 内 容 


(1) SELECT 子 句 中 “目标 表达 式 ” 的 各 种 使 用 形式 。 
(2) WHERE 子 句 中 “条 件 表达 式 ” 的 各 种 使 用 形式 。 
(3) GROUP BY 子 句 的 使 用 方法 。 
(4) 聚集 函数 的 使 用 方法 。 
四 、 预 备 知识 
(1) 数据 查询 是 数据 库 的 核心 操作 。SQL 使 用 SELECT 语句 进行 数据 查询 ， 该 语句 使 
用 方式 灵活 、 功 能 丰富 。 虽 然 SELECT 语句 的 完整 语法 较 复杂 ， 但 其 一 般 格式 如 下 : 
SELECT [ALLIDISTINCT] < 目标 列表 达 式 >[ 别 名 ] [< 目标 列表 达 式 > [别名 ]] … 
FROM < 表 名 或 视图 名 >[ 别 名 ][,< 表 名 或 视图 名 >[ 别 名 ]] .…|(<SELECT 语句 >)[AS]< 别 名 > 
[WHERE < 条 件 表达 式 >] 
[GROUP BY < 列 名 1>[HAVING< 条 件 表达 式 >]] 
[ORDER BY < 列 名 2> [ASCIDESC]]: 
整个 SELECT 语句 的 含义 是 : 根据 WHERE 子 句 的 条 件 表达 式 从 FROM 子 句 指定 的 
基本 表 、 视 图 或 派生 表 中 找 出 满足 条 件 的 元 组 ， 再 按 SELECT 子 句 中 的 目标 列表 达 式 选 出 
元 组 中 的 属性 值 形 成 结果 表 。 
如 果 有 GROUP BY 子 句 , 则 将 结果 按照 < 列 名 1> 的 值 进行 分 组 , 值 相等 的 元 组 为 一 组 。 
如 果 GROUP BY 子 句 带 HAVING 短语 ， 则 只 有 满足 指定 条 件 的 组 才 会 输出 。 
如 果 有 ORDER BY 子 句 ， 则 结果 还 要 按照 < 列 名 2> 的 值 的 升序 或 降序 排序 。 
(2) SELECT 子 句 的 < 目标 列表 达 式 > 的 可 选 格式 如 下 : 


*,< 表 名 >.*,COUNT( * ), 聚 集 函 数 ([DISTINCTIALL] < 列 名 > ),[< 表 名 >.]< 属 性 列 名 表达 式 > 


其 中 ，< 属 性 列 名 表达 式 > 可 以 是 由 属性 列 、 作 用 于 属性 列 的 聚集 函数 和 常量 的 任意 
算术 运算 (+， 洛 /) 组 成 的 运算 公式 。 
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(3) 聚集 函数 的 一 般 格式 : 
COUNT SUM /AVG/ MAX/ MIN([DISTINCTIALL] < 列 名 >) 


如 果 指 定 DISTINCT 短语 ， 表 示 在 计算 时 要 取消 指定 列 中 的 重复 值 ， 否 则 表示 不 取消 
重复 值 。 

(4) WHERE 子 句 的 < 条 件 表 达 式 > 的 可 选 格式 如 下 : 

@ < 属性 列 名 > 9 < 属性 列 名 > /< 常量 > /[ANYIALL](SELECT 语句 ) 

@ < 属性 列 名 > [NOT] BETWEEN < 属性 列 名 > / < 常量 > /SELECT 语句 )AND < 属性 
列 名 > /< 常量 > /SELECT 语句 ) 

@ < 属性 列 名 > [NOT] IN(< 值 1>[，< 值 2> ] .…)(SELECT 语句 ) 

@ < 属性 列 名 > [NOT] LIKE < 匹配 串 > 

@ < 属性 列 名 > IS [NOT] NULL 

@ [NOT] EXISTS (SELECT 语句 ) 

@ < 条 件 表达 式 > AND / OR < 条 件 表达 式 > 


五 、 实 验 步骤 


1. 无 条 件 查询 

(1) 查询 全 体 学 生 的 详细 信息 。( 查 询 全 部 列 ) 
SELECT* FROM Student ; 
或 


SELECT Sno,Sname,Ssex,Sage,Dno FROM Student: 
(2) 查询 全 体 学 生 的 姓名 、 性 别 。( 查 询 部 分 列 ) 
SELECT Sname,Ssex FROM Student'; 
(3) 查询 全 体 学 生 的 学 号 、 姓 名 、 出 生年 份 和 所 在 系 , 要 求 用 小 写字 母 表示 系 编号 。( 查 
询 经 过 计算 的 值 ) 
SELECT Sno,Sname, 2018-Sage as "Year of Birth, LOWER(Dno) ' 系 编号 ' 
FROM Student: 
(4) 查询 选修 了 课程 的 学 生 学 号 。( 消 除 取 值 重复 的 元 组 ) 
SELECT DISTINCT Sno FROM SC:; 
2. 条 件 查询 
(1) 比较 大 小 
Q@ 查询 信息 工程 系 (IS) 全 体 学 生 的 姓名 、 性 别 和 年 龄 。 


SELECT Sname, Ssex, Sage 
FROM Student 
WHERE Dno=TS': 
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@ 查询 考试 成 绩 为 优秀 (大 于 等 于 90 分 ) 的 学 生 的 学 号 、 姓 名 。 
SELECT DISTINCT Sno,Sname 
FROMSC 
WHERE Grade>=90: 
(2) 确定 范围 
@ 查询 所 有 年 龄 在 18 一 20 岁 (包括 18 岁 和 20 岁 ) 之 间 的 学 生 姓名 、 性 别 及 年 龄 。 














SELECT Sname, Ssex, Sage 

FROM Student 

WHERE Sage>=18 AND Sage<=20; 
或 

SELECT Sname, Ssex, Sage 

FROM Student 

WHERE Sage BETWEEN 18 AND 20; 


@ 查询 年 龄 不 在 18 一 20 岁 之 间 的 学 生 姓 名 、 性 别 及 年 龄 。 


SELECT Sname, Ssex, Sage 
FROM Student 
WHERE Sage NOT BETWEEN 18 AND 20; 
或 
SELECT Sname, Ssex, Sage 
FROM Student 
WHERE Sage<18 OR Sage>20: 
(3) 确定 集合 
Q@ 查询 信息 工程 系 和 数学 系 学 生 的 信息 。 
SELECT * FROM Student 
WHERE Dno IN (IS', MA'N); 
或 
SELECT * FROM Student 
WHERE Dno=TS' OR Dno=MA'; 
@ 查询 既 不 是 信息 工程 系 ， 也 不 是 数学 系 的 学 生 的 信息 。 
SELECT* FROM Student 
WHERE Dno NOT IN (TS MA); 
或 
SELECT* FROM Student 
WHERE Dnol=TS' AND Dno!=MA'; 


(4) 字符 匹配 

@ 查询 所 有 姓 “ 张 ”的 学 生 的 学 号 、 姓 名 和 性 别 。 
SELECT Sno, Sname, Ssex 
FROM Student 
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WHERE Sname LIKE ' 张 %0': 

@ 查询 姓 “ 张 ” 且 全 名 为 两 个 汉字 的 学 生 的 信息 。 
SELECT* FROM Student 
WHERE Sname LIKE 张 '; 

@ 查询 姓名 第 2 个 汉字 为 “小 ”的 学 生 的 信息 。 
SELECT * FROM Student 
WHERE Sname LIKE '， 小 9%6: 


@ 查询 所 有 不 姓 “ 张 ”的 学 生 姓名 和 年 龄 。 
SELECT Sname, Sage 
FROM Student 
WHERE Sname NOT LIKE ' 张 %6' 

@ 查询 课程 名 为 Power_ Design 的 课程 号 和 学 分 。 


SELECT Cno, Ceredit 
FROM Course 
WHERE Cname LIKE ' Power\ Design' ESCAPE \'; 


@ 查询 以 DB_ 开 头 ， 且 倒数 第 2 个 字符 为 i 的 课程 的 详细 情况 。 
SELECT*# 
FROM Course 
WHERE Cname LIKE 'DB\ %i 'ESCAPEN': 
(5) 空 值 查询 
@ 假设 某 些 学 生 选 修 课程 后 没有 参加 考试 ， 所 以 有 选课 记录 ， 但 没有 考试 成 绩 。 查 
询 缺 少 成 绩 的 学 生 的 学 号 和 相应 的 课程 号 。 
SELECT Sno,Cno 
FROM SC 
WHERE Grade IS NULL: 


@ 查询 所 有 有 选课 成 绩 的 学 生 学 号 和 课程 
SELECT Sno, Cno 


FROM SC 
WHERE GradeIS NOTNULL: 


3 


3. 查询 结果 排序 
(D 查询 选修 了 2 号 课程 的 学 生 的 学 号 和 成 绩 ， 并 按 成 绩 降 序 排列 。 


SELECT Sno, Grade 
EROM SC 

WHERE Cno='2' 

ORDER BY Grade DESC:; 
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(2) 查询 全 体 学 生 情 况 , 查询 结果 按 系 编号 升序 排列 , 同一 系 中 的 学 生 按 年 龄 降序 排列 。 


SELECT* 
FROM Student 
ORDER BY Dno, Sage DESC:; 


4. 聚集 函数 
(1) 查询 女生 总 人 数 。 


SELECT COUNT(*) FROM Student 
WHERE Ssex=' 女 '; 


(2) 查询 选修 了 课程 的 学 生 人 数 。 
SELECT COUNT(DISTINCT Sno) FROM SC; 
(3) 计算 选修 2 号 课程 的 学 生平 均 成 绩 。 
SELECT AVG(Grade) 
FROM SC 
WHERE Cno='2'; 
(4) 查询 选修 2 号 课程 的 学 生 最 高 分 数 。 


SELECT MAX(Grade) 
FROM SC 
WHERE Cno='2'; 


5. 查询 结果 分 组 
(1) 求 各 个 课程 号 及 相应 的 选课 人 数 。 
SELECT Cno , COUNT(Sno) as ' 选 课 人 数 ' 
FROM SC 
GROUP BY Cno; 
(2) 查询 选修 了 两 门 或 两 门 以 上 课程 的 学 生 学 号 。 


SELECT Sno 

FROMSC 

GROUP BY Sno 

HAVING COUNT(Cno)>=2:; 


六 、 实 验 报告 要 求 


(1) 实验 报告 必须 给 出 实现 的 SQL 语句 ， 并 对 SQL 语句 执行 前 后 各 个 基本 表 的 数据 
进行 分 析 ， 验 证 SQL 命令 的 正确 性 。 
(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 
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七 、 思 考题 


(1) 在 分 组 统计 查询 中 的 WHERE 和 HAVING 有 什么 区 别 ? 试 举例 说 明 。 

(2) 不 在 GROUP BY 子 句 中 出 现 的 属性 ， 是 否 可 以 出 现在 SELECT 子 句 中 ? 试 举例 
说 明 。 

(3) 在 GROUP BY 子 句 中 出 现 的 属性 ， 是 否 可 以 不 出 现在 SELECT 子 句 中 ? 试 举例 
说 明 。 
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实验 4 多 表 连 接 查 询 


熟练 掌握 SQL 查询 语句 的 一 般 格式 ， 灵 活 掌 握 各 类 连接 查询 的 使 用 。 


二 、 实 验 学 时 
1 学 时 。 


三 、 实 验 内 容 





(1) 等 值 与 非 等 值 连接 查询 。 
(2) 自然 连接 查询 。 

(3) 自身 连接 查询 。 

(4) 外 连接 查询 。 


四 、 预 备 知识 


(1) 多 表 的 连接 查询 ， 相 当 于 在 表 上 做 笛 卡 尔 积 。 
SELECT < 目标 列表 达 式 列表 > 
FROM 表 名 1, 表 名 2 
(2) 等 值 与 非 等 值 连接 。 
连接 查询 的 连接 条 件 或 连接 谓词 ， 其 一 般 格 式 如 下 : 
[< 表 名 1>.]< 列 名 1>< 比 较 运 算 符 >[< 表 名 2>.]< 列 名 2> 
其 中 ，< 比 较 运 算 符 > 主 要 有 =、>、<、>=、<=、!=。 当 连接 运算 符 为 = 时 ， 称 为 等 值 
连接 ， 否 则 称 为 不 等 值 连 接 。 
【 注 】 多 表 连 接 时 ， 当 某 列 名 在 两 张 表 中 同时 存在 时 ， 在 列 名 前 要 加 表 名 以 示 区 分 。 


(3) 自然 连接 。 


若 在 等 值 连接 中 把 目标 列 中 重复 的 属性 列 去 掉 则 为 自然 连接 。 


(4) 自身 连接 。 


连接 操作 的 对 象 是 一 张 表 与 其 自身 ， 称 为 表 的 自身 连接 。 


【 注 】 自 身 连 接 
名 ， 以 示 区 别 。 
(5) 外 连接 。 


因为 是 对 同一 张 表 操作 ， 为 区 分 对 该 表 操 作 的 顺序 ， 需 要 取 两 个 别 





如 果 把 悬浮 元 组 也 保存 在 结果 关系 中 ,而 在 其 他 属性 上 填写 空 值 NULL)， 这 种 连接 称 
为 外 连接 。 外 连接 还 可 分 为 左 外 连接 、 右 外 连接 。 
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五 、 实 验 步骤 


1. 等 值 连接 查询 
查询 每 个 学 生 及 其 选修 课程 的 情况 。 
SELECT Student.*, SC.* 


FROM Student, SC 
WHERE Student.Sno = SC.Sno: 


【 注 】 结 果 中 Sno 会 重复 出 现 。 

2. 自然 连接 查询 

查询 每 个 学 生 及 其 选修 课程 的 情况 ， 查 询 结 果 不 能 出 现 重复 属性 列 。 
SELECT Student.Sno, Sname, Ssex, Sage, Dno, Cno, Grade 


FROM Student, SC 
WHERE Student.Sno = SC.Sno; 


3. 自身 连接 查询 
查询 每 一 门 课 的 间接 选修 课 ( 即 选修 课 的 选修 课 )。 
SELECT A.Cno,A.Cname, B.Cpno 


FROM Course A, Course B 
WHERE A.Cpno =B.Cno; 


4. 外 连接 查询 

查询 每 个 学 生 及 其 选修 课程 的 情况 ， 碍 询 结果 要 求 包含 所 有 选课 学 生 。 
SELECT Student.Sno, Sname, Ssex, Sage, Dno, Cno, Grade 
FROM Student 


LEFT JOIN SC ON 
Student.Sno= SC.Sno; 








【 注 】 以 上 为 左 连接 操作 ， 也 可 以 用 以 下 的 右 连接 操作 代替 ， 其 结果 完全 相同 。 


SELECT Student.Sno, Sname, Ssex, Sage,Dno, Cno, Grade 
FROM SC 

RIGHT JOIN Student ON 

SC.Sno=Student.Sno; 


5. 多 表 连 接 查询 
查询 每 个 学 生 的 学 号 、 姓 名 、 选 修 的 课程 名 及 成 绩 。 


SELECT Student.Sno, Sname, Cname, Grade 
FROM Student, SC, Course 
WHERE Student.Sno= SC.Sno AND SC.Cno=Course.Cno: 
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6. 连接 查询 练习 


(1) 查询 全 体 学 生 学 号 、 姓 名 、 性 别 和 所 在 系 。 
(2) 查询 计算 机 系 年 龄 在 19 岁 以 上 的 学 生 的 学 号 、 姓 名 、 年 龄 。 
(3) 查询 选修 了 “数学 ”或 “数据 库 ” 课 程 学 生 的 学 号 、 姓 名 、 成 绩 。 
(4) 查询 每 个 学 生 的 学 号 、 姓 名 、 选 修 课 的 课程 名 及 成 绩 。 
(5) 查询 课程 成 绩 低 于 75 分 的 学 生 的 学 号 、 姓 名 、 选 修 课 的 课程 名 及 成 绩 。 
(1) SELECT Sno,Sname,Ssex,Dname 
FROM Student,Department 
WHERE Student.Dno=Department.Dno:; 
(2) SELECT Sno,Sname,Sage 
FROM Student,Department 
WHERE Sage>19 AND Student.Dno=Department.Dno AND Dname='" 计 算 机 系 '; 


(3) SELECT SC.Sno,Sname,Grade 
FROM Student,Course,SC 
WHERE Student.Sno=SC.Sno AND Course.Cno=SC.Cno AND (Cname=' 数 学 ' OR Cname=' 数 据 库 ) ; 


(4) SELECT SC.Sno,Sname,Cname,Grade 
FROM Student,Course,SC 
WHERE Student.Sno=SC.Sno AND Course.Cno=SC.Cno:; 


(5) SELECT SC.Sno,Sname,Cname,Grade 
FROM Student,Course,SC 
WHERE Student.Sno=SC.Sno AND Course.Cno=SC.Cno AND Grade<75; 


六 、 实 验 报告 要 求 
(1) 实验 报告 必须 给 出 实现 的 SQL 语句 ， 并 对 SQL 语句 执行 前 后 各 个 基本 表 的 数据 


进行 分 析 ， 验 证 SQL 命令 的 正确 性 。 
(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 


、 思 考题 


(D 讨论 如 何 提高 连接 查询 的 速度 ， 并 进行 实验 验证 。 
(2) 分 析 左 外 连接 、 右 外 连接 和 自然 连接 的 区 别 和 应 用 ， 并 举例 说 明 。 


第 4 章 课程 实验 


实验 5 答 套 查询 与 集合 查询 


一 、 实 验 目的 

熟练 掌握 嵌 套 查询 、 集 合 查询 的 使 用 ， 理 解 掌握 相关 子 查询 与 不 相关 子 查询 。 
二 、 实 验 学 时 

2 学 时 。 
三 、 实 验 内 容 

(1) 带 IN 谓词 的 子 查询 。 

(2) 带 比较 运算 符 的 子 查询 。 

(3) 带 ANY 或 ALL 谓词 的 子 查询 。 

(4) 带 EXISTS 谓词 的 子 查询 。 

(5) 集合 查询 。 


四 、 预 备 知识 


(1) 在 SQL 语言 中 , 一 个 SELECTFROM-WHERE 语句 称 为 一 个 查询 块 。 如 将 一 个 查 
询 块 撕 套 在 另 一 个 查询 块 的 WHERE 子 句 或 HAVING 短语 的 条 件 中 , 则 此 查询 称 为 嵌 套 查 
询 。 上 层 的 查询 称 为 外 查询 或 父 查 询 ， 下 层 的 查询 称 为 内 查询 或 子 查询 。 
SQL 语言 还 允许 多 层 嵌 套 查询 ， 即 子 查询 中 还 可 以 嵌 套 其 他 子 查询 。 
【 注 】 子 查询 的 SELECT 子 句 中 不 能 使 用 ORDER BY 子 句 。 
(2) IN 谓词 子 查询 。 
在 嵌 套 查询 中 ， 子 查询 的 结果 常常 是 一 个 集合 。 故 谓词 IN 经 常用 于 嵌 套 查询 ， 其 一 
般 格 式 如 下 : 
SELECT < 目标 列表 达 式 列表 > 
FROM 表 名 
WHERE 列 名 IN 
(SELECT 子 句 ) 
(3) 比较 运算 符 的 子 查询 。 
比较 运算 符 的 子 查询 是 指 父 查询 与 子 查询 之 间 通 过 比较 运算 符 进行 连接 的 嵌 套 查 
询 。 当 能 确切 知道 子 查询 返回 的 是 单个 值 时 ， 父 查询 与 子 查询 之 间 就 可 以 通过 比较 运算 符 
>、 汪 、<、< 二 、=、!=) 连 接 起 来 。 
(4) EXISTS 谓词 子 查 询 。 
带 EXISTS 谓词 的 子 查询 不 返回 任何 数据 ,只 产生 逻辑 真 值 TRUE 或 逻辑 假 值 FALSE。 
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车 内 层 查 询 结果 非 空 ， 则 外 层 的 WHERE 子 句 返回 真 值 ， 否 则 返回 假 值 。 




















回 真 值 或 假 值 ， 给 出 列 名 无 实际 意义 。 





EXISTS 引出 的 子 查询 ， 其 目标 列表 达 式 通常 都 用 *， 因 


为 带 EXISTS 的 子 查 询 只 返 


EXISTS 子 查 询 中 一 般 是 相关 子 查 询 ， 即 子 查 询 脱 离 父 查询 后 不 能 单独 执行 。 


(5) 不 相关 子 查询 与 相关 子 查询 。 


如 果子 查询 的 查询 条 件 不 依赖 于 父 查 询 ， 称 为 不 相关 子 查询 ; 依赖 于 父 查 询 ， 称 为 
相关 子 查询 。 不 相关 子 查 询 常用 的 求解 方法 是 由 里 向 外 处 理 ， 即 先 执 行 子 查询 ， 子 查询 的 
结果 用 于 建立 父 查 询 的 查询 条 件 。 相 关子 查询 的 求解 与 不 相关 子 查 询 的 求解 完全 不 同 ， 不 
能 一 次 将 子 查询 求解 出 来 ， 然 后 求解 父 查询 ， 由 于 子 查询 与 父 查询 相关 ， 因 此 必须 对 子 查 





询 反复 求 值 。 





(6) SELECT 语句 的 查询 结果 是 元 组 的 集合 , 因此 多 个 SELECT 语句 的 查询 结果 可 进行 
集合 操作 。 参 加 集合 操作 的 各 查询 结果 的 列 数 必须 相同 ， 对 应 项 的 数据 类 型 也 必须 相同 。 
常见 的 集合 操作 包括 并 操作 UNION、 交 操作 INTERSECT 和 差 操 作 EXCEPT。 


五 、 实 验 步骤 


1. IN 谓词 嵌 套 查询 


(1) 查询 与 “ 张 敏 ” 在 同一 个 系 学 习 的 学 生 信息 。 


【方法 一 】 谓词 不 相关 子 查询 
SELECT* 
FROM Student 
WHERE Dno IN 
(SELECT Dno 
FROM Student 
WHERE Sname=' 张 敏 ' 
» 
【方法 二 】 自 身 连接 查询 
SELECT S1.* 
FROM Student S1,Student S2 
WHERE S1.Dno=S2.Dno AND S2.Sname=' 张 敏 '; 


(2) 查询 选修 了 2 号 课程 的 学 生 学 号 、 姓 名 和 系 号 。 


【方法 一 】IN 谓词 不 相关 子 查 询 
SELECT Sno,Sname,Dno 
FROM Student 
WHERE Sno IN 
(SELECT Sno 
FROM SC 
WHERE Cno='2' 
六 


【方法 二 】 连 接 查 询 
SELECT Student.Sno,Sname,Dno 


FROM Student.SC 
WHERE Student.Sno = SC.Sno AND Cno='2' 


(3) 查询 选修 了 “数据 库 ”课程 的 学 生 学 号 、 姓 名 和 系 号 。 
【方法 一 】IN 谓词 不 相关 子 查 询 
SELECT Sno,Sname,Dno 
FROM Student 
WHERE Sno IN 
(SELECT Sno 
FROM SC 
WHERE Cno IN 
(SELECT Cno 
FROM Course 
WHERE Cname=' 数 据 库 ' 
) 
» 
【方法 二 】 连 接 查 询 
SELECT Student.Sno,Sname,Dno 
FROM Student,Course,SC 


WHERE Student.Sno=SC.Sno AND SC.Cno=Course.Cno AND Cname=' 数 据 库 '; 


(4) 查询 没有 选修 “数据 库 ” 课 程 的 学 生 的 学 号 和 姓名 。 


SELECT Sno,Sname 
FROM Student 
WHERE Sno NOTIN 
(SELECT Sno 
FROM SC 
WHERE Cno IN 
(SELECT Cno 
FROM Course 
WHERE Cname=' 数 据 库 ' 
) 
» 


2. 比较 运算 符 炭 套 查询 
(1) 查询 与 “ 张 敏 ”在 同一 个 系 学 习 的 学 生 信息 。 


SELECT * 
FROM Student 
WHERE Dno= 
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(SELECT Dno 
FROM Student 
WHERE Sname=' 张 敏 ' 
a 
(2) 找 出 每 个 学 生 超过 他 自己 选修 课程 平均 成 绩 的 课程 号 。 


SELECT Sno,Cno 
FROM SCX 
WHERE Grade>= 
(SELECTAVG(Grade) 
FROM SCY 
WHERE y.Sno=x.Sno 
): 








至 于 是 哪个 学 生 的 平均 成 绩 取决 于 参数 x.Sno 的 值 ， 而 该 参数 的 值 与 父 查询 相关 。 
3. ANY 或 ALL 谓词 能 套 查询 
(1) 查询 其 他 系 中 比 信息 工程 系 某 一 学 生年 龄 小 的 学 生 信 息 。 
【方法 一] 
SELECT* 


FROM Student 
WHERE Sage<ANY(SELECT Sage FROM Student WHERE Dno='IS'") AND Dno<>TS': 


【方法 二 】 
SELECT* 


FROM Student 
WHERE Sage<(SELECT MAX(Sage) FROM Student WHERE Dno=TS) AND Dno 一 TS' 


(2) 查询 其 他 系 中 比 信 息 工 程 系 所 有 学 生年 龄 都 小 的 学 生 信息 。 
【方法 一 】 
SELECT* 


FROM Student 
WHERE Sage<ALL(SELECT Sage FROM Student WHERE Dno=TS) AND Dno 一 TS'; 


【方法 二 】 
SELECT* 


FROM Student 
WHERE Sage<(SELECT MIN(Sage) FROM Student WHERE Dno=TS) AND Dno 一 TS' 


4. EXISTS 谓词 伐 套 查询 
(1) 查询 所 有 选修 了 2 号 课程 的 学 生 学 号 、 姓 名 。 


SELECT Sno,Sname 


【 注 】 此 查询 为 相关 子 查询 ， 子 查询 的 作用 是 求解 一 个 学 生 所 有 选修 课程 的 平均 成 绩 ， 
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FROM Student 
WHERE EXISTS 
(SELECT * 
FROM SC 
WHERE Sno=StudentSno AND Cno='2' 
); 
【 注 】 本 查询 为 相关 子 查询 ， 子 查询 的 查询 条 件 依 赖 于 父 查 询 Student.Sno 的 值 。 
(2) 查询 没有 选修 2 号 课程 的 学 生 学 号 、 姓 名 。 
SELECT Sno,Sname 
FROM Student 
WHERE NOT EXISTS 
(SELECT* 
FROM SC 
WHERE Sno=Student.Sno AND Cno='2' 
下 
(3) 用 带 谓词 EXISTS 的 子 查询 ， 查 询 与 “ 张 敏 ”在 同一 个 系 学 习 的 学 生 信息 。 
SELECT Sno,Sname,Dno 
FROM Student A 
WHERE EXISTS 
(SELECT* 
FROM Student B 
WHERE B.Dno=A.Dno AND B.Sname= 张 敏 ' 
% 
5. 并 运算 
查询 信息 工程 系 的 学 生 及 年 龄 不 大 于 18 岁 的 学 生 信 息 。 
【方法 一 】 
SELECT* FROM Student WHERE Dno='IS' 


UNION 
SELECT* FROM Student WHERE Sage<=18; 


【方法 二 】 
SELECT* FROM Student WHERE Dno ='S' OR Sage—18; 
6. 交 运 算 
(1) 查询 信息 工程 系 的 学 生 与 年 龄 不 大 于 18 岁 的 学 生 的 交集 。 
【方法 一 了 


SELECT* FROM Student WHERE Dno='IS' 
INTERSECT 





“50。 数据 库 系 统 原理 及 应 用 课程 设计 与 实验 指导 


SELECT * FROM Student WHERE Sage<=18: 
【方法 二 】 

SELECT * FROM Student WHERE Dno -TS' AND Sage<=18: 
(2) 查询 既 选 修了 1 号 课程 又 选修 了 2 号 课程 的 学 生 。 
【方法 一 】 

SELECT Sno FROM SC WHERE Cno='1' 


INTERSECT 
SELECT Sno FROM SC WHERE Cno=2'; 


【方法 二 】 
SELECT Sno 
FROM SC 
WHERE Cno='l' AND Sno IN 
(SELECT Sno 
FROM SC 
WHERE Cno=2' 
bs 
(3) 查询 学 号 为 201215121 和 201215122 的 学 生 同 时 选修 的 课程 的 课程 号 。 
【方法 一 】 
SELECT Cno FROM SC WHERE Sno='201215121' 


INTERSECT 
SELECT Cno FROM SC WHERE Sno='201215122'; 


【方法 2】 
SELECT Cno 
FROM SC 
WHERE Sno='201215121' AND Cno IN 
(SELECT Cno 
FROM SC 
WHERE Sno='201215122': 
x 
7. 差 运算 
(1) 查询 信息 工程 系 的 学 生 与 年 龄 不 大 于 18 岁 的 学 生 的 差 集 。 
【方法 一 】 
SELECT* FROM Student WHERE Dno='IS' 


EXCEPT 
SELECT* FROM Student WHERE Sage<=18: 


【方法 二 】 
SELECT * FROM Student WHERE Dno=TS' AND Sage>18: 
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(2) 查询 选修 了 1 号 课程 但 没有 选修 2 号 课程 的 学 生 学 号 。 
【方法 一 】 
SELECT Sno FROM SC WHERE Cno='1' 


EXCEPT 
SELECT Sno FROM SC WHERE Cno=2'; 


【方法 三 了 
SELECT Sno 
FROM SC 
WHERE Cno=1' AND Sno NOT IN 
(SELECT Sno 
FROM SC 
WHERE Cno='2' 
); 
(3) 查询 学 号 为 201215121 的 学 生 选 修 ， 但 没有 被 学 号 为 201215122 的 学 生 所 选修 的 
课程 的 课程 号 。 
【方法 一 】 
SELECT Cno FROM SC WHERE Sno='201215121' 


EXCEPT 
SELECT Cno FROM SC WHERE Sno='201215122'; 


【方法 二 】 


SELECT Cno 
FROM SC 
WHERE Sno='201215121' AND Cno NOT IN 
(SELECT Cno 
FROM SC 
WHERE Sno='201215122' 


» 
六 、 实 验 报告 要 求 
(1) 实验 报告 必须 给 出 实现 的 SQL 语句 ， 并 对 SQL 语句 执行 前 后 各 个 基本 表 的 数据 
进行 分 析 ， 验 证 SQL 命令 的 正确 性 。 
(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 
七 、 思 考题 


(D 试用 多 种 形式 表示 实验 中 的 查询 语句 ， 并 进行 比较 。 
(2) 试 分 析 不 相关 子 查询 及 相关 子 查询 的 求解 过 程 ， 并 举例 说 明 。 
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实验 6 索引 与 视图 


一 、 实 验 目的 
理解 SQL 的 视图 及 与 基本 表 的 区 别 ， 掌 握 SQL 索引 、 视 图 建立 、 修 改 和 删除 ， 掌 握 
如 何 应 用 视图 有 选择 地 查看 所 需 数 据 ， 并 熟悉 通过 视图 更 改 数据 表 中 数据 的 方法 。 
二 、 实 验 学 时 
2 学 时 。 
三 、 实 验 内 容 
(1) 索引 的 建立 、 修 改 和 删除 。 


(2) 视图 的 建立 、 修 改 和 删除 。 
(3) 查询 视图 。 


四 、 预 备 知识 


(1) 数据 库 索 引 类 似 于 图 书 中 的 索引 ， 是 加 快 查询 速度 的 有 效 手 段 ， 它 能 快速 定位 到 
需要 查询 的 内 容 ， 而 不 必 扫 描 整 个 数据 库 。 索 引 就 是 表 中 数据 和 相应 存储 位 置 的 列表 ， 可 
以 大 大 减少 数据 库 管理 系统 查找 数据 的 时 间 。 

用 户 可 以 根据 需要 在 基本 表 上 建立 一 个 或 多 个 索引 。 数 据 库 索引 有 多 种 类 型 ， 常 见 的 
索引 包括 顺序 文件 上 的 索引 、B+ 树 索引 、 散 列 索引 和 位 图 索引 等 。 

(2) 在 SQL 语言 中 ， 建 立 索引 使 用 CREATE INDEX 语句 ， 其 一 般 格 式 如 下 : 

CREATE [UNIQUE][CLUSTER]INDEX < 索引 名 > 
ON < 表 名 >(< 列 名 >[< 次 序 >][L.< 列 名 >[< 次 序 >]]...); 


对 于 已 经 建立 的 索引 ， 如 果 需 要 对 其 重 命名 ， 可 使 用 ALTER INDEX 语句 ， 其 一 般 格 
式 如 下 : 














ALTER INDEX < 旧 索 引 名 > RENAME TO < 新 索引 名 >; 





索引 建立 后 ， 由 系统 进行 使 用 和 维护 ， 不 需 用 户 干 预 。 但 对 于 一 些 不 必要 的 索引 可 
将 其 进行 删除 ， 删 除 索引 的 格式 如 下 : 


DROP INDEX < 索引 名 >; 














【 注 】DROP INDEX 只 能 删除 用 户 使 用 CREATE INDEX 语句 所 建立 的 索引 , 不 能 删除 
SQL Server 为 PRIMARY KEY 及 UNIQUE 约束 所 建立 的 索引 ， 这 些 索引 只 能 通过 删除 约 
束 或 删除 表 的 方法 来 删除 。 
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(3) 视图 是 从 一 个 或 几 个 基本 表 ( 或 视图 ) 导 出 的 表 , 其 结构 和 数据 是 建立 在 对 基本 表 的 
查询 基础 上 ， 是 查看 数据 库 表 中 数据 的 一 种 方法 。 视 图 是 一 种 逻辑 对 象 ， 是 一 种 虚 表 ， 
数据 库 中 只 存放 视图 的 定义 ， 而 不 存放 视图 对 应 的 数据 ， 这 些 数据 仍然 存放 在 原来 的 基 
本 表 中 。 

视图 昌 是 虚拟 表 ， 但 一 经 定义 ， 就 可 以 和 基本 表 一 样 被 删除 、 被 查询 ， 也 可 以 在 一 个 
视图 上 再 定义 新 的 视图 ， 但 对 视图 的 更 新 操作 会 有 一 定 的 限制 。 

(4) SQL 语言 使 用 CREATE VIEW 命令 来 建立 视图 ， 其 一 般 格式 如 下 : 

CREATE VIEW < 视图 名 > [ (< 列 名 > [, < 列 名 >]...)] 
AS < 子 查 询 > 
[WITH CHECK OPTION]: 
删除 视图 本 质 上 是 将 视图 的 定义 从 数据 字典 中 删除 ， 语 句 格式 如 下 : 
DROP VIEW < 视图 名 > [CASCADE]; 

视图 定义 后 ， 用 户 可 以 像 对 基本 表 一 样 对 视图 进行 查询 。 查 询 视图 时 ， 系 统 先 对 视图 
进行 有 效 性 检查 ， 检 查 通过 后 采用 视图 消解 法 完成 视图 查询 。 

更 新 视图 本 质 上 是 通过 视图 来 完成 对 基本 表 数 据 的 插入 、 删 除 和 修改 ， 也 是 通过 视图 
消解 法 ， 转 换 为 对 基本 表 的 更 新 操作 。 在 关系 数据 库 中 ， 不 是 所 有 视图 都 可 更 新 ， 一 般 行 
列子 集 视图 是 可 更 新 的 。 


五 、 实 验 步骤 























1. 利用 对 象 资源 管理 器 建立 索引 

(1) 在 对 象 资源 管理 器 窗 格 中 展开 指定 服务 器 下 的 数据 库 ， 找 到 需要 创建 索引 的 表 ， 
展开 其 下 的 “索引 ”文件 夹 ， 右 击 鼠 标 ， 从 快捷 菜单 中 选择 “新 建 索 引 ” 选 项 ， 如 图 4-14 
所 示 。 


四 口 dbo ,Department 
田 日 dbosc 
日 日 dbosudent 





(2) 进入 “新 建 索引 ”对 话 框 ， 如 图 4-15 所 示 。 在 “索引 名 称 ” 编 辑 框 内 输入 索引 名 
称 ， 在 “索引 类 型 ”下 拉 列 表 框 内 选择 所 要 创建 的 索引 类 型 。 如 要 创建 徐 索 引 ， 则 选择 
“聚集 ;如 要 创建 非 复 索引 ， 则 选择 “ 非 聚 集 ”;， 而 如 果 要 在 XML 数据 类 型 字段 上 创建 
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索引 ， 则 选择 “ 主 XML”; 如 要 创建 唯一 索引 ， 则 选择 “唯一 ” 复 选 框 。 





ba 
ee 
0 
Je 
Veo 
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于 要 和 U 帮 入 大 小 友信 站 NuLL 三 | 于 :> 
| 











图 4-15 “新 建 索引 ”对 话 杠 


(3) 单 击 “添加 ”按钮 ， 弹 出 选择 列 对 话 框 ， 从 中 选择 要 作为 索引 键 的 字段 ， 并 单 击 
“确定 ”按钮 ， 如 图 4-16 所 示 。 



































大 从 "dbostudent [SEE 
Oms 
渤 反 要 添加 到 杰 引 中 的 表 列 ; s ES 
加 | 多 大 小 标 R 区 证 NULL 什 
加 Sno char(9) 9 香 否 | 
加 ssex char(2) 3 否 否 
Sage smalint 2 否 是 
加 Dno char(2) 4 否 是 

区 本 区 于 








图 4-16 选择 索引 键 列 

(4) 完成 索引 类 型 的 设置 和 键 列 选择 后 ， 单 击 “ 新 建 索引 ”对 话 框 底部 的 “确定 ” 按 
钮 ， 即 可 完成 索引 的 创建 。 

(5) 如 果 需 要 删除 索引 ， 在 对 象 资源 管理 器 中 找到 该 索引 ， 右 击 鼠 标 ， 从 快捷 菜单 中 
选择 “删除 ”选项 ， 即 可 完成 删除 。 

2. 利用 TransactSQL 语句 建立 、 修 改 和 删除 索引 

(1) 建立 索引 。 

分 别 为 学 生 一 课程 数据 库 StudScore DB 中 的 Student、Course、SC 三 个 表 建 立 索 引 。 


其 中 ，Student 表 按 学 号 升序 建 唯一 索引 ，Course 表 按 课程 号 升序 建 唯一 索引 ，SC 表 按 学 
号 升序 和 课程 号 降序 建 唯一 索引 。 其 语句 分 别 如 下 : 


CREATE UNIQUE INDEX StuSno ON Student(Sno): 
CREATE UNIQUE INDEX CouCno ON Course(Cno): 
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CREATE UNIQUE INDEX SCno ON SC(Sno ASC, Cno DESC): 


TSQL 语句 建立 索引 如 图 4-17 所 示 。 





EeREATE UNIQUE INDEX Stusno ON Student (Sng 
CREATE UNIQUE INDEX CouCno ON Courss (Cne 
CREATE UNIQUE INDEX Scno ON Sc (Sne ASC, Cpe DESC) 


图 4-17 TSQL 语句 建立 索引 


(2) 修改 索引 。 

将 SC 表 的 SCno 索引 名 改 为 SCSno。 
ALTER INDEX SCno RENAME TO SCSno; 

(3) 删除 索引 。 

删除 Student 表 的 StuSno 索引 。 


DROP INDEX Student.StuSno:; 


3. 利用 对 象 资源 管理 器 实现 视图 的 建立 、 删 除 、 查 询 和 更 新 

(1) 在 对 象 资源 管理 器 的 树 状 目录 中 ， 展 开 要 进行 操作 的 数据 库 ， 选 择 “ 视 图 ” 碳 击 
鼠标 ， 在 弹出 的 快捷 菜单 中 选择 “新 建 视图 ”， 如 图 4-18 所 示 。 

(2) 在 弹出 的 “添加 表 ” 对 话 框 中 ， 列 出 了 指定 数据 库 中 所 有 用 户 定义 的 表 ， 可 以 从 
中 选择 构造 视图 所 需 的 一 个 或 者 多 个 基本 表 ， 选 择 完 毕 ， 单 击 “ 添 加 ”按钮 ， 如 图 4-19 
所 示 。 








和 连接- 可 于 了 回 当 


日 四 LG21505\SQLSEVER (SQL Server 11.0.3000 - L < “mh 
日 国 数据 库 Department 
田 国 系统 数据 库 SC 
田 入 数据 库 快照 || Eee 
田 国 ReportServer$SQLSEVER 
田 国 ReportServer$SQLSEVERTempDB 





日 国 sudscore DB 























图 4-18 新 建 视图 图 4-19 选择 构造 视图 的 基本 表 
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(3) 在 弹出 的 选择 属性 列 窗 格 中 ， 列 出 了 创建 视图 基本 表 的 全 部 属性 。 根 据 视图 定义 
的 需要 选择 相应 属性 列 ， 再 在 中 间 窗 格 的 “筛选 器 ”中 设置 创建 视图 的 条 件 ， 设 置 完毕 单 
击 工具 栏 上 的 “保存 ”按钮 ， 在 弹出 的 对 话 框 中 对 视图 进行 命名 。 在 Student 表 中 建立 信 
息 工程 系 学 生 的 视图 ， 如 图 4-20 所 示 。 














列 别名 和 要 输出 排序 类 型 排 忆 顺序 蒜 迁 器 或 - 
sno Student 可 
Sname Student 团 
s: Student 加 
Sage Student 可 





[BELECT Sno, Sname, Ssex Sage 
| dbo.Student 
IERE (Dno = 1S? 





Sno Sname Ssex Sage 
om | NULL NULL NULL 








图 4-20 信息 工程 系 学 生 的 视图 


(4) 视图 创建 好 后 ， 还 可 以 根据 需要 对 它 进行 修改 。 如 要 修改 ， 先 在 对 象 资源 管理 器 
的 树 状 目录 中 选择 该 视图 ， 右 击 鼠 标 ， 在 弹出 的 快捷 菜单 中 选择 “设计 ”， 然 后 可 在 弹出 的 
编辑 窗 格 中 进行 修改 操作 。 

(5) 如 要 删除 视图 ， 先 在 对 象 资源 管理 器 的 树 状 目录 中 选择 该 视图 ， 右 击 鼠 标 ， 在 弹 
出 的 快捷 菜单 中 选择 “删除 ”， 即 可 完成 删除 操作 。 

(6) 创建 好 的 视图 可 以 像 基本 表 一 样 ， 对 其 进行 查询 操作 。 


4. 利用 Transact-SQL 语句 实现 视图 的 建立 、 删 除 和 更 新 


(1) 建立 视图 。 
Q 建立 计算 机 系 学 生 的 视图 ST1。( 单 表 视 图 ) 


CREATE VIEW ST1 
AS 

SELECT* 

FROM Student 
WHERE Dno='CS'; 


@ 建立 计算 机 系 选修 了 2 号 课程 的 学 生 的 视图 ST2， 包 括 学 号 、 姓 名 、 成 绩 。( 多 表 
视图 ) 
CREATE VIEW ST2(Sno,Sname,Grade) 


AS 
SELECT Student.Sno,Sname,Grade 
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FROM Student,SC 
WHERE Dno='CS' AND Student. Sno=SC.Sno AND SC.Cno="2' 


@ 建立 计算 机 系 选修 了 2 号 课程 且 成 绩 不 及 格 的 学 生 的 视图 ST3。( 基 于 视图 的 视图 ) 


CREATE VIEW ST3 

AS 

SELECT Sno,Sname,Grade 
FROM ST2 

WHERE Grade<60; 


图 定义 一 个 反映 学 生出 生年 份 的 视图 ST4。( 表 达 式 视图 ) 
CREATE VIEW ST4(Sno,Sname,Sbirth) 
AS 


SELECT Sno,Sname,YEAR(GETDATE())-Sage 
FROM Student: 


@ 将 学 生 的 学 号 及 他 的 平均 成 绩 定义 为 一 个 视图 ST5。( 分 组 视图 ) 
CREATE VIEW ST5(Sno,Gavg) 
AS 
SELECT Sno,AVG(Grade) 


FROM SC 
GROUP BY Sno; 


@ 建立 学 生 的 学 号 、 姓 名 、 系 名 、 选 修 课 程 名 及 成 绩 的 视图 ST6。 


CREATE VIEW ST6 

AS 

SELECT Student.Sno,Sname,Dname,Cname,Grade 

FROM Student,Department,SC,Course 

WHERE Student.Dno=Department.Dno AND Student.Sno= SC.Sno AND SC.Cno=Course.Cno: 


(2) 删除 视图 。 
删除 视图 ST4。 


DROP VIEW ST4; 


(3) 更 新 视图 。 
Q@ 将 计算 机 系 学 生 视 图 ST1 中 学 号 为 201215125 的 学 生 姓名 改 为 Alice。 
UPDATE ST1 
SET Sname='Alice' 
WHERE Sno='201215125'; 
用 视图 消解 法 转换 后 的 更 新 语句 如 下 : 


UPDATE Student 
SET Sname='Alice' 
WHERE Sno='201215125' AND Dno= CS': 
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@ 向 计算 机 系 学 生 视 图 ST1 中 插入 一 个 新 的 学 生 记录 , 其 中 学 号 为 201531001, 姓名 
为 Tom。 
INSERT INTO STI1 
VALUES(201531001.Tomy); 
里 视图 消解 法 转换 后 的 更 新 语句 如 下 : 
INSERT INTO Student(Sno,Sname,Dno) 
VALUES(201531001"','Tom,', 'CS")'; 
图 删除 计算 机 系 学 生 视图 ST1 中 学 号 为 201215125 的 记录 。 


DELETE 
FROM ST1 
WHERE Sno='201215125'; 


用 视图 消解 法 转换 后 的 更 新 语句 如 下 : 
DELETE 


FROM Student 
WHERE Sno='201215125' AND Dno='CS'; 














5. 查询 视图 
(1) 在 计算 机 系 的 学 生 视图 ST1 中 找 出 男 学 生 的 信息 。 


SELECT* 
FROM STI1 
WHERE Ssex=' 男 '; 


用 视图 消解 法 转换 后 的 查询 语句 如 下 : 


SELECT * 
FROM Student 
WHERE Dno='CS' AND Ssex=' 男 '; 


(2) 查询 计算 机 系 选修 了 1 号 课程 的 学 生 。 


SELECT * 
FROM ST1.SC 
WHERE ST1.Sno=SC.Sno AND SC.Cno='l’; 


用 视图 消解 法 转换 后 的 查询 语句 如 下 : 
SELECT* 


FROM StudentSC 
WHERE Student.Dno='CS' AND StudentSno=SC.Sno AND SC.Cno='l’; 
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六 、 实 验 报告 要 求 

(1) 实验 报告 必须 给 出 实现 的 SQL 语句 ， 并 对 SQL 语句 执行 前 后 的 数据 进行 分 析 ， 
验证 SQL 命令 的 正确 性 。 

(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 
七 、 思 考题 

(1) 为 什么 要 建立 视图 ? 视图 和 基本 表 有 什么 不 同 ? 

(2) 视图 在 哪些 情况 下 需 对 字段 名 进行 重 命名 ? 试 举例 说 明 。 

(3) 在 什么 情况 下 , 使 用 视图 可 以 提高 数据 库 的 性 能 ， 加快 数据 的 查询 效率 ? 试 举例 
说 明 。 
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实验 7 T-SQL 程序 设计 


一 、 实 验 目的 
掌握 Transact-SQL 语言 的 基础 知识 、Transact-SQL 程序 设计 的 控制 结构 及 程序 设计 
方法 : 


三 、 实 验 内 容 
在 查询 分 析 中 利用 Transact-SQL 进行 简单 的 程序 设计 。 
四 、 预 备 知识 


1. SQL 中 的 变量 

(1) 全 局 变量 : 全 局 变量 是 用 来 记录 SQL Server 服务 器 活动 状态 的 变量 ， 它 们 实际 上 
是 系统 函数 ,用户 只 可 以 使 用 , 不 可 以 重新 定义 和 赋值 。 全 局 变量 的 名 字 以 @@ 开 头 ，SQL 
Server 提供 的 全 局 变量 共有 33 个 。 

(2) 局 部 变量 : 局 部 变量 是 用 户 定义 的 变量 ， 用 来 存放 临时 数据 ， 使 用 前 一 定 要 先进 
行 定 义 。 局 部 变量 的 名 字 以 @ 开 头 ， 用 DECLARE 语句 声明 ， 用 SET 语句 或 SELECT 语 
句 为 其 赋值 。 局 部 变量 的 作用 域 从 声明 它们 的 地 方 开始 到 声明 它们 的 批 处 理 或 存储 过 程 
结尾 。 

声明 局 部 变量 语句 ，DECLARE @ 局 部 变量 名 数据 类 型 [, .…] 

用 SET 语句 给 局 部 变量 赋值 语句 : SET @ 局 部 变量 名 = 表达 式 

用 SELECT 语句 给 局 部 变量 赋值 语句 : SELECT @ 局 部 变量 名 = 表达 式 [, .…] 


2. SQL 中 的 基本 函数 


(1) 字符 串 函 数 : LENO、UPPERO、LOWER0O、RIGHTO、LEFTO、SUBSTRINGO、 
CHARINDEX0O、STRO、REPLACEO 等 。 

(2) 数学 函数 : 常用 的 数学 函数 通常 对 作为 参数 提供 的 输入 值 执行 计算 ， 并 返回 一 个 
数字 值 ， 如 ABSO、POWERO、SQUARE0O、SQRIO、ROUNDO、RAND0 等 。 

(3) 日 期 和 时 间 函 数 : 日 期 和 时 间 函 数 对 日 期 和 时 间 输 入 值 执行 操作 ， 并 返回 一 个 字 
符 串 、 数 字 值 或 日 期 和 时 间 值 , 如 GETDAIE0、DAIEADD0O、DAIEIFF0O0、DAIEPART0O、 
ISDATE0、DAY0、MONTHO、YEARO 等 。 
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(4) 数据 类 型 转换 函数 。 

CAST 函数 : CAST(expression AS data type) 

CONVERT 函数 : CONVERT(data_ type[(lengthb)]. expression [ . style ] ) 

3. SQL 中 的 流程 控制 语句 

SQL 语言 提供 了 一 些 可 以 用 于 改变 语句 执行 顺序 的 命令 ， 称 为 流程 控制 语句 。 流 程控 
制 语句 与 常见 的 程序 设计 语言 类 似 ， 主 要 包含 以 下 几 种 。 

(1) USE 语句 

语法 格式 : USE {database} 

功能 : 切换 到 数据 库 。 

(2) PRINT 语句 

语法 格式 : PRINT msg_strlvariablelstring expr 

功能 : 打印 字符 串 常量 、 变 量 或 返回 字符 串 的 表达 式 。 

(3) BEGIN...END 语句 


语法 格式 : 

BEGIN 

<SQL 语句 或 程序 块 > 
END 


在 条 件 和 循环 等 流程 控制 语句 中 ， 要 执行 两 个 或 两 个 以 上 的 Transact-SQL 语句 ， 就 需 
要 使 用 BEGIN...END 将 它们 组 织 成 一 个 语句 块 ， 作 为 一 个 整体 来 处 理 。 
(4) IF...ELSE 语句 
语法 格式 : 
正 < 条 件 表达 式 > 
< 语句 列表 1> 
[ELSE 
< 语句 列表 2>] 
(5) WHILE 语句 
WHILE 语句 可 以 设置 重复 执行 SQL 语句 或 语句 块 的 条 件 , 只 要 指定 的 条 件 为 True (条 
件 成 立 )， 就 重复 执行 语句 。 语 法 格式 : 
WHILE < 条 件 表达 式 > 
BEGIN 
< 语句 系列 1> 
[BREAK] 
< 语句 系列 2> 
[CONTINUE] 
< 语句 系列 3> 
END 
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其 中 , BREAK 命令 让 程序 完全 跳出 循环 语句 , 结束 WHILE 命令 的 执行 ; CONTINUE 
命令 让 程序 跳 过 CONTINUE 命令 之 后 的 语句 回 到 WHILE 循环 的 第 一 条 命令 继续 循环 。 
WHILE 语句 可 以 使 用 嵌 套 。 

(6) CASE 语句 

CASE 表达 式 可 以 计算 多 个 条 件 ， 并 将 其 中 一 个 符合 条 件 的 结果 表达 式 返 回 。 语 法 
格式 : 

CASE 字段 名 或 变量 名 
WHEN 逻辑 表达 式 1 THEN 结果 表达 式 1 
[WHEN 逻辑 表达 式 2 THEN 结果 表达 式 2 
nl 结果 表达 式 n] 

END 





五 、 实 验 步骤 


1. 变量 的 定义 、 赋 值 与 输出 

(1) 创建 字符 型 局 部 变量 @varl、@var2 并 赋值 ， 然 后 用 PRINT 语句 输出 变量 的 值 。 
DECLARE @varl CHAR(30), @var2 CHAR(30), @var3 CHAR(60) 
SET @varl= 广东 理工 学 院 ' 


SET @var2= ' 信 息 工程 系 ' 
SET (@var3=(@varl+(@var2 


PRINT @varl -- 用 PRINT 语句 显示 字符 型 变量 的 值 
PRINT @var?2 

PRINT @var3 

PRINT CHAR(10) -- 换 行 


PRINT 学 校 : +@varl -- 用 PRINT 语句 显示 字符 型 常量 和 字符 型 变量 的 值 
PRINT ' 系 别 : +@var2 
PRINT CHAR(10) 
PRINT @varl+@var2 -- 用 PRINT 语句 显示 两 个 字符 型 变量 的 值 
(2) 创建 字符 型 局 部 变量 @varl、@var2 并 赋值 ， 然 后 用 SELECT 语句 输出 变量 的 值 。 
DECLARE @varl CHAR(30),@var2 CHAR(30).@var3 CHAR(60) 
SET @varl= 广 东 理工 学 院 ' 
SET @var2= 信 息 工 程 系 ' 
SET @var3=(@varl+(@var2 


SELECT @var3 -用 SELECT 语句 显示 一 个 字符 型 变量 的 值 
SELECT @varl+@var2 -用 SELECT 语句 显示 两 个 字符 型 变量 的 值 ， 用 + 连接 
SELECT @varl.@var2 -用 SELECT 语句 显示 两 个 字符 型 变量 的 值 ， 用 ,连接 


SELECT 学校: +G@varl+' 系 别 : +@var2 。 -- 用 SELECT 语句 显示 常量 与 字符 型 变量 的 值 
SELECT 学 校 : ,\@varl,' 系 别 : ',@var2 
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(3) 创建 一 个 名 为 @xb 的 局 部 变量 ， 并 在 SELECT 语句 中 使 用 该 局 部 变量 查找 Student 
表 中 所 有 性 别 为 “ 女 ”的 学 生 记录 。 


USE StudScore DB 
DECLARE @xb CHAR(C) 
SET @xb=' 女 ' 
SELECT * FROM Student WHERE Ssex=@xb 
(4) 创建 一 个 名 为 @xm 的 局 部 变量 ， 用 它 返回 学 号 为 201215123 的 学 生 姓名 。 
USE StudScore DB 
DECLARE @xm CHAR(8) 
SET @xm=(SELECT Sname FROM Student WHERE Sno='201215123") 
PRINT @xm 
或 
USE StudScore DB 
DECLARE @xm CHAR(8) 
SELECT @xm=Sname FROM Student WHERE Sno='201215123' 
PRINT @xm 


(5) BEGIN. . .END 语句 的 应 用 。 





BEGIN 
DECLARE @varl CHAR(20),@var?2 FLOAT 
SET @varl=' 圆 周 率 ' 
SET @var2="3.1415926' 
PRINT @varl 
PRINT @var2 
END 
GO 


2. 流程 控制 语句 
(1) 给 x 赋值 ， 并 判断 其 值 是 “ 正 数 ”还 是 “ 非 正 数 ”。 
DECLARE @x INT 
SET @x=100 
IF @x>0 
了 PRINT ' 该 数 为 正 数 ' 
ELSE 
了 PRINT ' 该 数 为 非 正 数 ' 
(2) 判断 学 生成 绩 表 中 是 否 存在 考 满 分 的 成 绩 信息 ， 若 有 ， 输 出 该 学 生成 绩 信 息 ， 否 
则 ， 输 出 “没有 考 满分 的 学 生 !”。 
IF EXISTS(SELECT * FROM SC WHERE Grade=100) 


BEGIN 
PRINT "有 考 满分 的 学 生 :' 
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PRINT CHAR(10) 
SELECT * FROM SC WHERE Grade=100 
END 
ELSE 
PRINT ' 没 有 考 满分 的 学 生 ! 
和 (x<D) 
(3) 给 x 赋值 5， 按 公式 y=12x-1 (1 三 x<10), 计算 y 的 值 并 输出 。 
3x+2 (x 二 10) 


DECLARE @x INT,@y INT 
SET @x=5 
IF @x<l 
SET @y=@x 
ELSE 
BEGIN 
下 @x<10 
SET @y=2*@x-1 
ELSE 
SET @y=3*@x+2 
END 
PRINT x=+CAST(@x as CHAR) 
PRINT y=+CONVERT(CHAR(8),@y) 


(4) 给 定 一 个 成 绩 ， 判 断 相 应 的 等 级 。 


DECLARE @¢j NTQib CHAR(O) 

SET @cj=78' 

SET @jb=CASE 
WHEN @cj>=90 AND @cj<=100THEN  ' 优 ' 
WHEN @cj>=80AND  ' 良 ' 
WHEN @cj>=70 中 ' 
WHEN @cj>-60 “及 格 ' 
ELSE ' 不 及 格 ' 

END 
PRINT CAST(@cij As CHAR)+@ib 
GO 


(5) 输出 SC 表 中 “ 刘 勇 (学 号 201215121)” 的 “数据 库 (课程 号 1)” 成 绩 及 对 应 的 





USE StudScore DB 
DECLARE @cj NTQijb CHAR(6) 
SET @cj=(SELECT Grade FROM SC WHERE Sno='201215121' and Cno='1) 
SET @jb=CASE 
WHEN @cj>=90AND @cj 一 100THEN ' 优 ' 
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WHEN @cj>=80AND  ' 良 ' 
WHEN @cj>=70 中 ' 
WHEN @cj>=60 “' 及 格 ' 
ELSE ' 不 及 格 ' 
END 
PRINT CAST(@cj As CHAR)+@ib 
GO 


(6) 求 s=1+2+3+4+...+100 的 值 。 


DECLARE @s INT,@i INT 
SET @i=1 
SET @s=0 
WHILE @i<=100 
BEGIN 
SET @s=@s+@1 
SET @i=@i+1 
END 
PRINT @s 
(7) 输出 九 九 乘法 表 。 
【方法 一 】 
DECLARE Qi SMALLINTLOQI SMALLINTQstrVARCHAR(100) 
PRINT' 九 九 乘法 表 ' 
SET @i=1 
WHILE @i<=9 
BEGIN 
SELECT @j=1,@str=" 
WHILE @j<=@i 
SELECT @str=@str+CAST(@j AS CHAR(1))+*+CAST(@i AS CHAr(1))+'="+CAST(@i* 
@j AS CHAR(2))+ SPACE(2),@j=@i+1 
PRINT @str 
SET @i=@it+1 
END 
【方法 二 】 
DECLARE Qi SMALLINLOQO SMALLINLQstr VARCHAR(100) 
PRINT' 九 九 乘法 表 ' 
SET @i=1 
WHILE @i<=9 
BEGIN 
SET @j=1 
SET @str=" 
WHILE @j 一 Qi 
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BEGIN 
SET @str-@str+CAST(@j AS CHAR(1)+*"+CAST(@i AS CHAR(1)+'="+CAST(@i* 
@j AS CHAR(2))+ SPACE(?) 
SET @j=@j+1 
END 
PRINT @str 
SET @i=@i+1 
END 


3. 自 定 义 函 数 的 使 用 
(1) 创建 一 个 内 联 表 值 函数 fun1， 返 回 某 个 系 学 生 的 信息 。 


CREATE FUNCTION funl(@xih CHAR(4)) 
RETURNS TABLE 
AS 
RETURN 
(SELECT * FROM Student WHERE Dno=(@xih) 
(2) 调用 内 联 表 函 数 fun1， 查 询 “ 计 算 机 系 ”学 生 的 信息 。 
SELECT* FROM fun1('CS') 
(3) 定义 一 个 函数 fn2， 当 给 定 一 门 课程 名 称 时 ， 计 算 选 修 该 门 课程 的 学 生 人 数 。 
CREATE FUNCTION fun2(@Cname VARCHAR(20)) 
RETURNS INT 
AS 
BEGIN 
DECLARE @Counts INT 
SELECT @Counts= 
(SELECT Count(*) FROM SC WHERE 
Cno=(SELECT Cno FROM Course WHERE Cname=@Cname)) 
RETURN @Counts 
END 
(4) 编写 一 段 工 SQL 脚本 程序 调用 上 述 函 数 。 当 向 SC 表 插 入 一 条 记录 时 ， 首 先 调用 
函数 fun2， 检 索 选修 该 门 课程 的 学 生 人 数 ， 若 学 生 人 数 小 于 50 人 ， 则 该 记录 插入 到 SC 
表 ， 人 允许 学 生 选 修 该 门 课程 ， 否 则 不 执行 插入 动作 。 
DECLARE @kch CHAR(3),@kcm VARCHAR(20) 
DECLARE @rs INT 
SET @kcnr' 信 息 系统 ' 
SELECT @kch=Cno FROM Course WHERE Cname=@kcm 
SELECT @rs=dbo.fun2(@kcm) 
下 @rs<50 
INSERT into SC VALUES('201215130',(@kch,85) 
Go 
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六 、 实 验 报告 要 求 


(D 实验 报告 中 要 对 建立 自 定义 函数 的 代码 进行 详细 分 析 。 
(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 


七 、 思 考题 
试 比较 Transact-SQL 语言 和 程序 设计 语言 中 ， 变 量 、 流 程控 制 和 自 定义 函数 的 异同 。 
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实验 8 存储 过 程 


一 、 实 验 目的 


了 解 存储 过 程 的 概念 和 功能 ， 掌 握 存 储 过 程 的 创建 方法 和 步骤 ， 掌 握 存 储 过 程 的 使 用 
方法 。 


二 、 实 验 学 时 
2 学 时 。 
三 、 实 验 内 容 


(1) 建立 存储 过 程 及 执行 存储 过 程 。 
(2) 管理 存储 过 程 ， 查 看 存储 过 程 代码 ， 修 改 存储 过 程 ， 删 除 存储 过 程 。 


四 、 预 备 知识 


(1) 存储 过 程 是 使 用 SQL 语句 和 控制 语句 预先 编辑 好 的 、 能 实现 特定 数据 操作 功能 的 
SQL 代码 模块 , 它 与 特定 的 数据 库 相 关联 , 经 过 编译 和 优化 后 存储 在 SQL Server 服务 器 上 。 
户 可 以 像 使 用 函数 一 样 重复 调用 存储 过 程 。 使 用 存储 过 程 有 以 下 三 个 优点 : 运行 效率 高 ; 
能 降低 客户 机 和 服务 器 之 间 的 通信 量 ; 方便 实施 企业 规则 。 

(2) 在 工 SQL 中 存储 过 程 分 为 三 类 : 系统 提供 的 存储 过 程 、 用 户 自 定义 存储 过 程 和 扩 
展 存储 过 程 。 

系统 提供 的 存储 过 程 定义 在 系统 数据 库 master 中 ， 是 由 系统 自动 创建 的 ， 并 以 sp 为 
前 级 。 在 SQL Server 中 有 许多 管理 活动 和 信息 活动 ， 都 可 以 使 用 系统 存储 过 程 来 执行 。 

用 户 自 定义 存储 过 程 是 指 用 户 根据 自身 需要 ， 为 完成 某 一 特定 功能 ， 在 用 户 数 据 库 中 
创建 的 存储 过 程 。 用 户 可 以 创建 全 局 临时 存储 过 程 (存储 过 程 名 前 面 加 # 名 和 局 部 临时 存储 
过 程 (存储 过 程 名 前 面 加 约 ， 它 们 都 存放 在 tempdb 数据 库 上 。 全 局 临时 存储 过 程 可 以 在 所 
有 会 话 中 使 用 ， 即 所 有 用 户 均 可 以 访问 该 过 程 ， 局 部 临时 存储 过 程 只 能 在 创建 它 的 会 话 中 
可 用 ， 当 前 会 话 结束 时 除去 。 

扩展 存储 过 程 以 在 SQL Server 环境 外 执行 的 动态 链接 库 (Dynamic-Link Libraries, DLL) 
来 实现 ， 通 过 前 级 xp 来 标识 ， 以 与 存储 过 程 相似 的 方式 来 执行 。 

(3) 可 使 用 CREATE PROCEDURE 命令 来 创建 用 户 自 定义 存储 过 程 ， 其 一 般 格 式 如 下 : 

CREATE { PROC | PROCEDURE } [EDURE] procedure_name [ : number ] 


[ { @parameter data type } 
[VARYING ] [= default ] [OUTPUT ] [ .…n ] 
[WITH { RECOMPILE | ENCRYPTION | RECOMPILE ,ENCRYTION } ] 
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[FOR REPLICATION ] 
AS sql statement[ ...n ] 


(4) 如 果 希 望 查看 存储 过 程 的 定义 信息 ， 可 以 使 用 sp_helptext 系统 存储 过 程 ， 其 语句 
格式 如 下 : 
EXECUTEIECEC sp_helptext 存储 过 程 名 
(5) 执行 、 删 除 存储 过 程 的 SQL 语句 一 般 格 式 分 别 如 下 : 
EXEC 过 程 名 ([ 参 数 1, 参数 2.]); 
DROP 过 程 名 (); 
五 、 实 验 步 又 
1. 利用 对 象 资源 管理 器 创建 存储 过 程 
(1) 在 对 象 资源 管理 器 窗 格 中 展开 指定 服务 器 下 的 数据 库 ， 找 到 需要 操作 的 数据 库 ， 
展开 其 下 的 “可 编程 性 ”文件 夹 ， 选 择 “新 建 存储 过 程 ” 并 右 击 鼠 标 ， 从 快捷 菜单 中 选择 
“新 建 存储 过 程 ”选项 ， 如 图 4-21 所 示 。 
(2) 出 现 图 4-22 所 示 的 显示 CREATE PROCEDURE 语句 的 模板 ， 可 以 修改 要 创建 的 
存储 过 程 的 名 称 ， 然 后 加 入 存储 过 程 所 包含 的 SQL 语句 。 
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图 4-21 新 建 存储 过 程 图 4-22 创建 存储 过 程 模板 








(3) 修改 完毕 ， 单 击 工具 栏 上 的 “执行 ”按钮 ， 即 可 创建 一 个 存储 过 程 。 
2. 利用 Transact-SQL 语句 创建 存储 过 程 

(1) 利用 存储 过 程 查找 Student 表 中 所 有 学 生 的 记录 。 

【创建 存储 过 程 】 

CREATE PROCEDURE Prol 


AS 
SELECT* FROM Student: 


【调用 存储 过 程 】 


EXEC Prol; 
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(2) 利用 存储 过 程 查找 Student 表 中 某 学 号 的 记录 。 
【创建 存储 过 程 】 
CREATE PROCEDURE Pro2 


@xh CHAR(10) 
AS 
SELECT * FROM Student WHERE Sno=@xh:; 
【调用 存储 过 程 】 
EXEC Pro2 '201215121'; 
(3) 利用 存储 过 程 查 找 SC 表 中 某 学 号 、 某 门 课程 的 记录 。 
【创建 存储 过 程 】 
CREATE PROCEDURE Pro3 
@xh CHAR(10),@kch CHAR(6) 
AS 
SELECT * FROM SC 
WHERE Sno=@xh AND Cno=@kch; 
【调用 存储 过 程 】 
EXEC Pro3 '201215121','1'; 
(4) 创建 一 个 存储 过 程 Pro4， 将 课程 表 中 某 门 课程 的 学 分 修改 为 指定 的 值 ， 其 中 课程 
、 学 分 指定 的 值 通过 参数 传递 , 并 多 次 调用 执行 该 存储 过 程 来 修改 不 同 的 课程 的 学 分 值 。 
【创建 存储 过 程 
CREAIE PROCEDURE Pro4 
@kch CHAR(6),@xf INT 
AS 
UPDATE Course 
SET Ceredit-@xf 
WHERE Cno=@kch:; 
【调用 存储 过 程 】 
EXEC Pro4 '1',2; 
EXEC Pro4 2',4; 
(5) 创建 删除 某 一 学 生 记 录 的 存储 过 程 。 
【创建 存储 过 程 】 
CREATE PROCEDURE Pro5 
@xh CHAR(10) 
AS 
DELETE FROM Student WHERE Sno=(@xh:; 
【调用 存储 过 程 】 


EXEC Pro5 '201215123'; 
































(6) 创建 一 个 带 返 回 值 的 存储 过 程 ， 返 回 某 学 生 的 平均 成 绩 。 
【方法 一 】 
【创建 存储 过 程 】 

CREATE PROCEDURE Pro6 

@xh CHAR(10) 

AS 

DECLARE @pifINT 

SELECT @pjf=AVG(Grade) 

FROM SC 

WHERE Sno=@xh: 

RETURN @pijf: 
【调用 存储 过 程 】 

DECLARE @pjcj INT: 

EXEC @pjcj=Pro6 201215121'; 

PRINT 'pjcj="+CAST(@pjcj AS CHAR(10)): 
[方法 二】 
【创建 存储 过 程 】 

CREAIE PROCEDURE Pro7 

@xh CHAR(10),@pjf INT OUTPUT 

AS 

SELECT @pijf= AVG(Grade) 

FROM SC 

WHERE Sno=@xh:; 
【调用 存储 过 程 】 

DECLARE @picj INT; 

EXEC Pro7 '201215121',@pjcj OUTPUT' 

SELECT @pjcj: 
(7) 创建 存储 过 程 ， 可 返回 指定 课程 号 的 该 门 课 程 的 平均 成 绩 。 
【创建 存储 过 程 】 

CREATE PROCEDURE Pro8 

@kch CHAR(6),@pjf INT OUTPUT 

AS 

SELECT @pjf=AVG(Grade) FROM SC WHERE Cno=(@kch:; 
【调用 存储 过 程 】 

DECLARE @pjcj INT: 

EXEC Pro8 '1',@picj OUTPUT: 

PRINT @picj: 
(8) 创建 存储 过 程 ， 完 成 以 下 功能 ， 针对 表 SC， 统 计 任意 一 门 课 的 平均 成 绩 。 
Q@ 创建 需要 的 表 结构 。 
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根据 实验 要 求 ， 统 计 任 意 一 门 课 的 平均 成 绩 ， 因 此 要 建立 表 Avggrade， 第 一 列 cname 
显示 统计 的 课程 名 称 ， 第 二 列 avgg 显示 选修 了 该 课程 的 学 生平 均 成 绩 。 


CREATE TABLE Avggrade 
(cname CHAR(20), 

avgg NUMERIC(10.,6) 

); 

@ 编写 存储 过 程 。 

CREATE PROCEDURE collect avggrade 

AS 

BEGIN 

DECLARE 一 声明 局 部 变量 @cumame,@curcno,@curavgg 

@curmame CHAR(20), 

@curcno CHAR(6), 

@curavgg NUMERIC(10.6) 

DECLARE 一 声明 游标 mycursor 

mycursor CURSOR FOR 

SELECT cno,cname FROM course -查询 课程 号 和 课程 名 

OPEN mycursor -- 打 开 游标 

-- 执 行 第 一 次 提取 ， 得 到 结果 集 的 首 行 ， 取 结果 送 入 变量 @curcno 和 @cumame 

FETCH NEXT from mycursor INTO Q@curcno.Q@cumame; 

-- 检 测 @Q@FETCH STATUS， 若 仍 有 行 ， 则 继续 循环 

-- 只 要 上 次 提取 获得 成 功 ， 就 会 执行 下 面 的 提取 

while @@FETCH_STATUS=0 

BEGIN 

-- 求 该 课程 的 平均 值 送 入 变量 

SELECT @curavge=AVG(grade) FROM SC WHERE cno=@curcno; 

一 向 Avggrade 表 中 插入 记录 ， 包 括 课程 名 称 和 平均 成 绩 

INSERT INTO Avggrade VALUES(@curmame,@curavgg): 

-游标 推进 一 行 ， 取 结果 送 入 变量 

FETCH NEXT from mycursor INTO @curcno.@cumame; 

END 

CLOSE mycursor -- 关 闭 游标 

DEALLOCATE mycursor -- 释 放 游 标 

END 


@ 执行 存储 过 程 。 
首先 执行 编写 好 的 存储 过 程 collect_avggrade， 然 后 在 表 Avggrade 中 查看 执行 结果 。 


EXEC collect avggrade: 
SELECT * FROM Avggrade; 


(9) 创建 存储 过 程 ， 完 成 以 下 功能 : 针对 表 SC， 将 学 生 选课 成 绩 从 百分制 改 为 等 级 制 
( 即 A、B、C、D、B)。 
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@ 修改 表 SC 的 结构 。 
于 之 前 的 成 绩 值 为 整数 型 ， 而 修改 后 的 结果 为 字符 型 ， 因 此 在 SC 中 先 增加 列 
newgrade， 存 放 换算 后 的 成 绩 。 


ALIER TABLE SC add newgrade CHAR(): 
@ 创建 存储 过 程 change_critical。 


CREATE PROCEDURE change critical 

AS 

BEGIN 

DECLARE 

@chgrade CHAR()， 一 声明 变量 

@sno CHAR(10), 

@cno CHAR(6)， 

(@grade INT 

DECLARE 一 声明 游标 currecord 
currecord CURSOR FOR SELECT sno,cno,grade FROM SC; 
OPEN currecord 一 打开 游标 

-- 游 标 推进 一 行 ， 取 结果 送 入 变量 @curcno 和 @cumame 
FETCH NEXT FROM currecord INTO Q@sno,Q@cno,Q@sgrade; 
WHILE @@FETCH STATUS=0 























BEGIN 

下 @grade<60 -- 如 果 成 绩 低 于 60 分 ， 将 成 绩 置 为 E 
SET @chgrade='E'; 

ELSE 

下 @grade<70 -- 如 果 成 绩 >60 且 <70， 将 成 绩 置 为 D 
SET @chgrade="D'; 

ELSE 

下 @grade<80 -- 如 果 成 绩 >70 且 <80， 将 成 绩 置 为 C 
SET @chgrade='C'; 

ELSE 

下 @grade<90 -- 如 果 成 绩 >80 上 且 <90， 将 成 绩 置 为 B 
SET @chgrade='B'; 

ELSE -- 如 果 成 绩 高 于 90 分 ， 将 成 绩 置 为 A 
SET @chgrade='A'; 


一 修改 newgrade 列 值 ， 填 入 换算 后 的 成 绩 
UPDAIE SC SET newgrade=@chgrade WHERE sno=(@sno AND cno=@cno: 
FETCH NEXT FROM curecord INTO Q@sno.Q@cno,Q@grade: 


END 

CLOSE currecord 一 关闭 游标 
DEALLOCATE currecord -释放 游标 

ALTER TABLE SC DROP COLUMN Grade: -删除 原 有 的 列 Grade 


一 执行 系统 存储 过 程 将 newgrade 列 改 名 为 Grade 
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EXEC sp_rename 'SC.[newegrade]','Grade'"COLUMN' 
END 


@ 执行 存储 过 程 。 
EXEC change critical; 
(10) 删除 存储 过 程 Prol 。 


DROP PROCEDURE Prol: 

六 、 实 验 报告 要 求 

(1) 实验 报告 中 要 对 建立 的 存储 过 程 代码 进行 详细 分 析 。 

(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 
七 、 思 考题 

(1) 试 比较 存储 过 程 中 的 参数 传递 与 程序 设计 中 的 参数 传递 的 异同 。 

(2) 存储 过 程 中 的 SELECT 语句 与 普通 的 SELECT 语句 格式 有 何不 同 ? 执行 方法 有 
何不 同 ? 
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实验 9 触发 器 
一 、 实 验 目的 
理解 触发 器 的 作用 , 学 会 使 用 Transact-SQL 语言 创建 触发 器 , 掌握 触发 器 的 使 用 方法 。 
二 、 实 验 学 时 
2 学 时 。 
三 、 实 验 内 容 


(1) 利用 Transact-SQL 语言 创建 触发 器 。 
(2) 触发 器 的 使 用 。 


四 、 预 备 知识 


(1) 触发 器 是 一 种 特殊 的 存储 过 程 ， 它 是 用 Transact-SQL 编写 的 程序 ， 但 与 存储 过 程 
中 的 EXECUTE 执行 命令 不 同 ， 它 只 能 是 在 用 户 对 某 一 表 内 的 数据 做 插入 (INSERT)、 更 新 
(UPDATE) 和 删除 (DELETE) 操 作 时 被 触发 执行 ， 这 时 ，SQL Server 会 自动 执行 触发 器 所 定 
义 的 SQL 语句 。 

(2) 触发 器 的 主要 作用 是 能 够 实现 由 主键 和 外 键 所 不 能 保证 的 复杂 的 参照 完整 性 和 数 
据 的 一 致 性 。 它 能 够 对 数据 库 中 的 相关 表 进 行 级 联 修改 ， 强 制 比 CHECK 约束 更 复杂 的 数 
据 完 整 性 ， 并 自 定义 错误 消息 ， 维 护 非 规范 化 数据 ， 以 及 比较 数据 修改 前 后 的 状态 。 在 下 
列 情况 下 ， 使 用 触发 器 将 强制 实现 复杂 的 引用 完整 性 。 

@ 强制 数据 库 间 的 引用 完整 性 。 

@ 创建 多 行 触发 器 ， 当 插入 、 更 新 或 者 删除 多 行 数据 时 ， 必 须 编写 一 个 处 理 多 行 数 
据 的 触发 器 。 

@ 执行 级 联 更 新 或 级 联 删 除 等 动作 。 

@ 级 联 修 改 数据 库 中 所 有 相关 表 。 

@ 撤销 或 者 回 滚 违反 引用 完整 性 的 操作 ， 防 止 非法 修改 数据 。 

(3) DELETED 表 和 INSERTED 表 。 

在 使 用 触发 器 过 程 中 ，SQL Server 使 用 到 两 个 特殊 的 表 : DELETED 表 和 INSERTED 
表 。 这 是 两 个 逻辑 表 ， 由 系统 来 自 创 建 和 维护 ， 用 户 不 能 对 它们 进行 修改 。 它 们 存放 在 内 
存 中 ， 其 结构 总 是 与 被 该 触发 器 作用 的 表 的 结构 相同 ， 触 发 器 执行 完成 后 ， 与 该 触发 器 相 
关 的 这 两 个 表 也 会 被 删除 。 

在 DELETED 表 中 存放 UPDATE 和 DELETE 影响 的 旧 数 据 行 。 在 执行 UPDATE 和 
DELETE 时 先 将 数据 从 基本 表 中 删除 ， 然 后 将 删除 的 数据 转移 到 DELETED 表 中 。 在 
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INSERTED 表 中 存放 UPDATE 和 INSERT 影响 的 数据 。 当 用 户 执行 UPDATE 和 INSERT 
时 ， 将 数据 添加 到 基本 表 中 ， 同 时 ， 将 数据 行 的 备份 复制 到 INSERTED 临时 表 中 。 
(4) SQL Server 系统 中 ， 按 照 触发 事件 的 不 同 可 以 把 触发 器 分 为 两 大 类 : DML 触发 器 

和 DDL 触发 器 。 对 于 不 同 的 触发 器 ， 其 创建 的 语法 多 数 相 似 ， 其 区 别 与 定义 表示 触发 器 
的 特性 有 关 。 创 建 一 个 触发 器 定义 的 基本 语法 如 下 : 

CREATE TRIGGER 触发 器 名 

ON { tablelview } 

砍 

{ FOR | AFTER | INSTEAD OF } 

{ [DELETE ][] [INSERT ] [,] [UPDATE] } 

AS 

T-SQL 语句 组 

入 


五 、 实 验 步骤 


(1) 向 Student 表 插 入 一 条 记录 时 ， 向 客户 端 显示 一 条 “您 正在 插入 学 生 的 信息 !” 消 息 。 
【创建 触发 器 】 


CREATE TRIGGER Tril 
ON Student 

AFTER INSERT 

AS 

PRINT ' 您 正在 插入 学 生 的 信息 ! “ 


【调用 触发 器 】 
INSERT INTO Student(Sno,Sname,Dno) 
VALUES(201331002', ‘Tonny', 'MA') ; 


(2) 创建 触发 器 ， 实 现在 成 绩 表 中 插入 一 条 记录 后 ， 触 发 触发 器 ， 显 示 该 记录 。 
【创建 触发 器 】 


CREATE TRIGGER Tri2 
ON SC 

AFTER INSERT 

AS 

DECLARE @xh CHAR(10) 

SELECT @xh=Sno FROM INSERTED 
SELECT * FROM INSERTED 

PRINT @xht+' 同 学 的 信息 成 功 插 入 ! '; 


【调用 触发 器 】 


INSERT INTO SC(Sno,Cno,Grade) 
VALUES (201331002",'5',70); 
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(3) 在 学 生 表 Student 中 创建 一 个 触发 器 Ti3， 当 删除 学 生 表 Student 中 的 学 生 记 录 时 ， 
自动 删除 成 绩 表 SC 中 相应 学 生 的 选课 记录 。 
【创建 触发 器 】 
CREATE TRIGGER Tri3 
ON Student 
AFTER DELETE 
AS 
DELETE SC WHERE Sno IN(SELECT Sno FROM DELETED); 
【调用 触发 器 】 
DELETE Student WHERE Sno='201331002'; 
【 注 】 实 现 级 联 删除 时 ， 因 为 Student 表 和 SC 表 的 主键 、 外 键 关系 ， 应 先 将 “INSERT 
和 UPDATE 规范 ”中 的 “更 新 规则 ”和 “删除 规则 ”设置 为 “ 层 琶 ”， 如 图 4-23 所 示 。 


MioesoR SQL Server Moanagemert stdio 
立体 有 ”名声 视图 V) 项 目 P) 委 讼 计 种 工具 宣 DW) 社区 (Om(H) 











有 RERN | 访 | 动 起 久 | 记 | 芒 晶 多孔 目 信访 也 
十 | 四] 必 说 风电 回忆 

于 旬 语 天 合理 坑 了 下 关 | 责 - dbostudentr | 下 

这 入 (0) | 珊 = 四 3 

日 图 ENovooy (6QL Serer 9013d | so 
日 国 对 s 声 














[7 





Sorh 





图 4-23 设置 “ 层 受 ” 





(4) 创建 触发 器 Ti4， 实 现 更 改 一 个 学 生 表 Student 的 学 号 后 ， 触 动 触发 器 ， 使 成 绩 表 
SC 中 该 学 生 的 学 号 也 相应 更 改 。 
【创建 触发 器 】 


CREATE TRIGGER Tri4 

ON Student 

FOR UPDATE 

AS 

一 判断 是 否 成 功 执行 更 新 语句 ， 如 果 成 功 更 新 一 条 数据 ， 则 @@rowcount =1 
I @@rowcount =0 RETURN 

一 定义 变量 来 接收 新 学 号 @xh， 旧 学 号 @jxh 

DECLARE @xh CHAR,@jxh CHAR 

一 获取 更 新 后 的 新 值 

SELECT @xh=Sno FROM INSERTED 
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一 获取 更 新 前 的 老 值 
SELECT @jxh=Sno FROM DELETED 
一 验证 成 绩 表 中 是 否 有 这 个 学 生 
IF EXISTS(SELECT * FROM SC WHERE Sno=(@jxh) 
BEGIN 。 -如果 有 才 更 新 
UPDATE SC 
SET Sno = @xh 
WHERE Sno=@jxh 
END 


【调用 触发 器 】 
UPDATE Student 


SET Sno="123456789' 
WHERE Sname= ' 张 敏 '; 


(5) 在 学 生 表 Student 中 定义 一 个 触发 器 Tri5, 保证 新 添加 的 学 生 的 年 龄 在 15 一 30 岁 
之 间 。 
【创建 触发 器 】 


CREATE TRIGGER Tiis 
ON Student 
FOR INSERT 
AS 
IF (SELECT Sage FROM INSERTED)>30 OR (SELECT Sage FROM INSERTED)<15 
BEGIN 
PRINT ' 年 龄 在 15~30 岁 之 间 ' 
ROLLBACK 
END 


【调用 触发 器 】 
INSERT 
INTO Student(Sno,Sname,Ssex,Sage,Dno) 
VALUES(201231414', 王 涛 , 男 ',18,'IS'); 
(6) 在 成 绩 表 SC 中 定义 一 个 触发 器 Tri6， 当 插入 或 者 修改 一 个 记录 时 , 确保 此 记录 的 
成 绩 (Grade) 在 0 一 100 分 之 间 。 
【创建 触发 器 】 


CREATE TRIGGER Tn6 

ONSC 

FOR INSERT.UPDATE 

AS 

DECLARE @cj SMALLINT 

SELECT @cj=Grade FROM INSERTED 
IF(@¢j>-0) AND (@¢j—100)) 

















as。T9 。 


BEGIN 
PRINT ' 操 作 完 成 ! 
RETURN 

END 

了 PRINT ' 成 绩 超出 0~100 的 范围 ' 
ROLLBACK TRANSACTION 


【调用 触发 器 】 
INSERT 


INTO SC(Sno,Cno,Grade) 
VALUES(C201231414'1,190): 

















六 、 实 验 报告 要 求 
(1) 实验 报告 中 要 对 建立 的 触发 器 代码 进行 详细 分 析 。 
(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 


七 、 思 考题 


(1) 试 比较 触发 器 与 存储 过 程 的 异同 。 
(2) 试 分 析 如 何 利用 触发 器 实现 较为 复杂 的 用 户 自 定义 完整 性 。 
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实验 10 数据 库 的 安全 


、 实 验 目 的 
加 深 对 数据 库 安全 性 的 理解 ， 掌 握 SQL Server 中 有 关 用 户 、 角 色 及 操作 权限 的 管理 方 














法 ， 掌 握 SQL 授权 语句 的 基本 格式 ， 掌 握 运用 授权 语句 向 用 户 授权 及 收回 权限 。 
二 、 实 验 学 时 

2 学 时 。 
三 、 实 验 内 容 


(1) 设置 SQL Server 的 安全 认证 模式 。 
(2) SQL Server 的 用 户 和 角色 管理 。 
(3) 设置 和 管理 数据 操作 权限 。 


四 、 预 备 知识 


1. 数据 库 的 安全 控制 机 制 


(1) 用 户 身份 鉴别 : 数据 库 管理 系统 提供 的 最 外 层 安全 保护 措施 。 系 统 提供 一 定 的 方 
式 让 用 户 标识 自己 的 名 字 或 身份 ， 每 次 用 户 要 求 进 入 系统 时 ， 由 系统 进行 核对 ， 通 过 鉴别 
后 才 提供 使 用 DBMS 的 全 权限 。 

(2) 存 取 控 制 : 用 户 权限 定义 和 合法 权限 检查 机 制 一 起 组 成 了 DBMS 的 存 取 控 制 子 系 
统 ， 确 保 只 有 授权 用 户 才能 访问 数据 库 ， 未 被 授权 用 户 无 权 访问 数据 库 。 

(3) 定义 视图 : 为 不 同 用 户 定义 不 同 视图 ， 把 数据 对 象限 定 在 一 定 范围 内 ， 把 要 保密 
的 数据 对 无 权 存 取 这 些 数据 的 用 户 隐藏 起 来 。 

(4) 审计 : 启用 一 个 专用 的 审计 日 志 ， 系 统 自 动 将 用 户 对 数据 库 的 所 有 操作 记录 在 上 
面 。 可 以 利用 审计 日 志 监 控 数 据 库 中 的 各 种 行为 ， 找 出 非法 存 取 数据 的 人 、 时 间 及 内 容 。 

(5) 数据 加 密 : 防止 数据 库 中 数据 在 存储 和 传输 中 失 密 的 有 效 手段 ， 基 本 思想 是 根据 
一 定 的 算法 在 数据 存储 或 传输 过 程 中 将 明文 转换 为 密 文 。 

2. SQL Server 的 身份 验证 模式 


(1) Windows 身份 验证 模式 : 将 Windows 系统 登录 账户 映射 到 SQL Server 系统 中 ， 人 多 
许 Windows 服务 器 验证 用 户 。 

(2) SQL Server 和 Windows 混合 模式 : 混合 模式 允许 用 户 使 用 Windows 身份 验证 模式 
或 SQL Server 身份 验证 模式 与 SQL Server 实例 连接 , 最 适合 用 于 外 界 用 户 访问 数据 库 或 不 
能 登录 到 Windows 域 时 。 
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3. 数据 库 登录 管理 


(1) 账号 与 角色 。 

账号 包括 超级 账号 SA( 即 数据 库 管理 员 账 号 ) 和 用 户 自 定义 账号 。 

具有 相同 权限 的 用 户 称 为 角色 ， 包 括 系 统 预定 义 的 固定 角色 和 用 户 根据 自己 的 需要 定 

义 的 用 户 角色 。 

(2) 权限 管理 。 

权限 的 管理 包含 如 下 三 个 内 容 。 

e 授予 权限 (GRANT): 允许 用 户 或 角色 具有 某 种 操作 权 。 

e 收回 权限 (REVOKE): 不 允许 用 户 或 角色 具有 某 种 操作 权 , 或 者 收回 曾经 授予 的 
权限 。 

e 拒绝 访问 (DENY): 拒绝 某 用 户 或 角色 具有 某 种 操作 权 ， 即 使 用 户 或 角色 由 于 继承 
而 获得 这 种 操作 权 ， 也 不 允许 执行 相应 的 操作 。 


五 、 实 验 步骤 


SQL Server 中 ， 用 户 分 为 两 类 ， 一 类 是 服务 器 登录 用 户 ， 另 一 类 是 数据 库 登 录用 户 ， 
这 两 类 用 户 综合 起 来 才能 完成 对 数据 库 的 管理 和 权限 设置 。 服 务 器 登录 方式 有 两 种 ， 一 种 
是 Windows 身份 登录 账号 ， 另 一 种 是 SQL Server 身份 登录 账号 。 

1. 创建 SQL Server 服务 器 登录 用 户 名 


(1) 在 对 象 资源 管理 器 中 创建 使 用 Windows 身份 验证 的 服务 器 登录 名 。 

@ 创建 需要 的 Windows 用 户 。 打 开 计 算 机 “控制 面板 ”下 的 “管理 工具 ”， 找 到 “ 计 
算 机 管理 ”打开 “本 地 用 户 和 组 ”节点 ， 单 击 “ 用 户 ” 在 用 户 列表 右 击 鼠 标 ， 选 择 “ 新 
用 户 ” 如 图 4-24 所 示 。 

@ 在 弹出 的 对 话 框 中 输入 自己 需要 的 用 户 名 和 密码 ， 如 图 4-25 所 示 。 
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图 4-24 新 建 用 户 图 4-25 输入 用 户 名 和 密码 








@ 打开 SQL Server Management Studio， 在 对 象 资源 管理 器 中 展开 “安全 性 ”节点 ， 
在 “登录 名 ”下 可 查看 已 存在 的 登录 账号 ,右键 单 击 “ 安 全 性 ”， 选 择 “ 新 建 ” 一 “登录 ”， 
如 图 4-26 所 示 。 
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| 到 也 加 号 
日 了 BLG21505\SQLSEVER (SQL Server 11.0.3000 - LG2150 
日 筷 数 兰 幸 
回国 系统 歼 宏 志 


田 国 数 扰 者 快照 

田 国 ReportServer$SQLSEVER 

田 国 ReportServer$SQLSEVERTempDB 
田 国 StudScore_ DB 





图 4-26 ”新建 登 录 


@ 弹出 “新 建 登 录 名 ”对 话 框 ， 如 图 4-27 所 示 。 单 击 “ 搜 索 ”， 弹 出 “选择 用 户 或 组 ” 
对 话 框 ， 如 图 4-28 所 示 。 单 击 “ 高 级 ” 弹出 “选择 用 户 或 组 ” 另 一 对 话 框 ， 如 图 4-29 所 示 。 
单 击 “ 立 即 查 找 ” 查找 已 经 存在 的 用 户 。 





选择 比 对 旬 类 型 
膝 记 或 内 而 志 全 主体 
查 顶 这 置 ): 

| ess 


输入 委 选择 人 名 d 象 名 称 BtD) 到 ) 



































图 4-29 “选择 用 户 或 组 ”对 话 框 2 


@@ 在 搜索 结果 中 选择 刚才 创建 的 Windows 用 户 名 ， 单 击 “确定 ”按钮 ， 则 在 对 象 资 
源 管理 器 下 的 登录 名 中 ， 将 显示 刚刚 创建 的 用 户 ， 如 图 4-30 所 示 。 


。83 。 


日 图 LG21505\SQLSEVER (SQL Server 11.0.3000 - LG21505WA 
日 镶 数据 库 
田 国 系统 数据 库 
田 国 数据 库 快照 
田 国 ReportServer$SQLSEVER 
田 国 ReportServer$SQLSEVERTempDB 


访 ##MS_PolicyEventprocessingLogin## 
谍 ##MS_PolicyTsqlExecutionLogin## 


| re 


态 NT AUTHORITN\SYSTEM 

态 NT Service\MSSQLSSQLSEVER 

态 NT SERVICE\ReportServer$SQLSEVER 
态 NT SERVICE\SQLAgent$SQLSEVER 
态 NT SERVICE\SQLWriter 

岛 NT SERVICE\Winmgmt 

入 sa 


图 4-30 成 功 创建 Windows 身份 验证 登录 名 


(2) 在 对 象 资源 管理 器 中 创建 使 用 SQL Server 身份 验证 的 服务 器 登录 名 。 

@ 打开 SQL Server Management Studio， 在 对 象 资源 管理 器 中 展开 “安全 性 ”节点 ， 
在 “登录 名 ”下 可 查看 已 存在 的 登录 账号 ， 右 键 单 击 “ 安 全 性 ” 选择 “新 建 ”一 “登录 ” 
如 图 4-26 所 示 。 

@ 弹出 “新 建 登 录 名 ”对 话 框 ， 选 中 “SQL Server 身份 验证 ” 输入 登录 名 和 密码 ， 
如 图 4-31 所 示 。 





sqlServerUser2 
Windors 身份 验证 0 


加 SQL Server 身份 验证 S) 
密码 中) Seeeee 
确认 密码 人) S090909| 





图 4-31 创建 SQL Server 身份 验证 登录 名 

(3) 利用 SQL 语句 创建 服务 器 登录 账号 。 
Windows 身 份 验证 : 

CREATE LOGIN "2011-20120510CTsqlServerUser3" FROM WINDOWS 
SQL Server 身份 验证 : 

CREATE LOGIN "sqlServerUser4" WITH PASSWORD='123456' 
(4) 使 用 系统 存储 过 程 创 建 服务 器 登录 账号 。 
Windows 身份 验证 : 


sp_grantlogin '2011-20120510CI\sqlServerUserS' 
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SQL Server 身份 验证 : 
sp_addlogin 'sqlServerUser6','123456" 
(5) 删除 服务 器 登录 账号 。 
可 以 直接 在 SQL Server Management Studio 中 单 击 删除 ， 也 可 使 用 工 SQL 语句 。 
删除 Windows 登录 账号 : 
sp_revokelogin "2011 -20120510CTsqlServerUserl" 
删除 SQL Server 登录 账号 : 
sp_droplogin sql- ServerUser4 





2. 创建 数据 库 登 录用 户 名 


(1) 在 对 象 资源 管理 器 的 “数据 库 ” 节 点 中 ,找到 需 添加 用 户 的 数据 库 ， 如 StudScore_ 
DB,， 展开 StudScore_DB 节点 ， 右 击 “ 安 全 性 ”节点 ,弹出 功能 列表 ， 选择“ 新 建 ”一 “用 





田 国 ReportServer$SQLSEVER 
9 OReportServer$SQLSEVERTempDB 
日 国 StudScore_DB 





图 4-32 新 建 用 户 
(2) 弹出 “新 建 数 据 库 用 户 ” 对 话 框 ， 如 图 4-33 所 示 ， 在 对 话 框 中 设置 用 户 的 有 关 属 
性 。 默认 的 架构 是 dbo， 默 认 的 角色 是 public， 单 击 “确定 ”创建 完成 ， 该 用 户 出 现在 对 应 
数据 库 的 “安全 性 ”一 “用 户 ” 节 点 中 。 

















Le21S05\sqlServerVserl 


默认 架构 5) 
dbo 











图 4-33 设置 用 户 属性 
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3. 设置 和 管理 数据 操作 权限 


(1) 新 建 测试 用 户 。 
@ 添加 登录 用 户 和 密码 。 
EXEC sp_addlogin 'sqlServerUser7,'123456' 
@ 使 其 成 为 当前 数据 库 的 合法 用 户 。 
EXEC sp_grantdbaccess 'sqlServerUser7' 
(2) 设置 操作 授权 。 
@ 授予 对 自己 数据 库 的 所 有 权限 。 
EXEC sp_addrolemember'db_owner,'sp_addrolemember 
@ 设置 具体 操作 权限 。 


-授予 对 所 有 用 户 表 的 操作 权限 
GRANT SELECTINSERTUPDATE.DELETE TO sqlServerUser7 
-- 授 予 sqlServerUser7 SELECTUPDAITE 到 具体 的 表 
GRANT SELECT,UPDATE ON SC TO sqlServerUser7 
-- 授 予 sqlServerUser7 SELECT,UPDATE 到 具体 的 表 和 列 
GRANT SELECT,UPDATE ON SC(Sno,Cno,Grade) TO sqlServerUser7 
-- 禁 止 sqlServerUser7 对 所 有 用 户 表 的 操作 权限 
DENY SELECT,INSERT,UPDATE,DELETE TO sqlServerUser7 
-禁止 sqlServerUser7 SELECT,UPDATE 到 具体 的 表 
DENY SELECT,UPDATE ON SC TO sqlServerUser7 
-- 禁 止 sqlServerUser7 SELECT,UPDATE 到 具体 的 表 和 列 
DENY SELECTLUPDAIE ON SC(Sno,Cno,Grade) TO sqlServerUser7 
-删除 sqlServerUser7 对 所 有 用 户 表 的 授权 信息 
REVOKE SELECTINSERTUPDAIE,DELETE TO sqlServerUser7 
-授予 sqlServerUser7 对 具有 创建 表 、 视 图 、 存 储 过 程 等 的 操作 权限 
GRANT CREATE TABLE,CREATE VIEW,CREATE PROC TO sqlServerUser7 
-禁止 sqlServerUser7 对 具有 创建 表 、 视 图 、 存 储 过 程 等 的 操作 权限 
DENY CREATE TABLE,CREATE VIEW.CREATE PROC TO sqlServerUser7 
一 删除 sqlServerUser7 对 具有 创建 表 、 视 图 、 存 储 过 程 等 的 授权 信息 
REVOKE CREATE TABLE,CREATE VIEW,CREATE PROC TO sqlServerUser7 
GO 


(3) 删除 测试 用 户 。 


EXEC sp_revokedbaccess 'sqlServerUser7' ”-- 移 除 用 户 对 数据 库 的 访问 权限 
EXEC sp_droplogin 'sqlServerUser7' 一 删除 登录 用 户 
GO 


六 、 实 验 报告 要 求 
(1) 实验 报告 中 要 对 SQL 语句 代码 进行 详细 分 析 。 
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(2) 实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 
七 、 思 考题 


(1) 分 析 使 用 角色 进行 权限 分 配 有 何 优 缺 点 。 
(2) 试用 对 象 资源 管理 器 来 设置 和 管理 数据 操作 权限 。 
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实验 11 数据 库 备份 和 还 原 


一 、 实 验 目的 
了 解 SQL Server 的 数据 备份 和 恢复 机 制 ,掌握 SQL Server 中 数据 库 的 分 离 、 附 加 、 备 
份 和 还 原 的 方法 。 
二 、 实 验 学 时 
2 学 时 。 
三 、 实 验 内 容 
(1) 数据 库 的 分 离 和 附加 。 
(2) 数据 库 的 备份 和 还 原 。 
四 、 预 备 知识 


1. 数据 库 恢复 

尽管 数据 库 系 统 采取 了 多 种 保护 措施 来 防止 数据 库 的 安全 性 和 完整 性 被 破坏 ， 但 计算 
机 系统 中 硬件 的 故障 、 软 件 的 错误 、 操 作 的 失误 及 恶意 的 破坏 仍 不 可 避免 ， 这 些 故障 会 影 
响 数据 库 中 数据 的 正确 性 ， 甚 至 破坏 数据 库 。 因 此 ，DBMS 必须 具有 把 数据 库 从 错误 状态 
恢复 到 某 一 已 知 的 正确 状态 的 功能 ， 即 数据 库 的 恢复 。 

2. 备份 和 恢复 体系 结构 


(1) 备份 方式 。 
@ 完全 数据 库 备份 :这 种 方式 备份 数据 的 所 有 数据 文件 和 备份 过 程 中 发 生活 动 的 日 
志文 件 。 完 全 数据 库 备份 、 恢 复 的 SQL 语句 格式 如 下 : 
BUCKUP DATABASE 数据 库 名 TO DISK= 地址 ' WITH INIT 
RESTORE DATABASE 数据 库 名 FROM DISK=' 地 址 ' WITH REPLACE 
@ 差异 数据 库 备 份 : 这 种 方式 只 备份 最 近 一 次 完全 数据 库 备 份 以 来 被 修改 的 那些 数 
据 ， 可 以 花费 较 少 的 时 间 和 空间 。 当 发 生 故 障 需要 恢复 时 ， 首 先 执行 完全 备份 恢复 ， 然 后 
执行 差异 备份 。 差 异 数据 库 备份 、 恢 复 的 SQL 语句 格式 如 下 : 
BACKUP DATABASE 数据 库 名 TO DISK=' 地 址 ' 
DIFFERENTIAL 


RESTORE DATABASE 数据 库 名 FROM DISK=' 地 址 ' WITH NONRECOVERY 
RESTORE DATABASE 数据 库 名 FROM DISK=' 地 址 ' WITH REPLACE 


@ 事务 日 志 备 份 ， 这 种 方式 备份 自 上 次 事务 日 志 备份 以 来 到 当前 事务 日 志 末 尾 的 部 
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分 ， 它 并 不 备份 数据 库 本 身 ， 比 完全 数据 库 备 份 节省 时 间 和 空间 。 当 系统 出 现 故 障 时 ， 首 
先 恢复 完全 数据 库 备份 ， 然 后 恢复 日 志 备份 。SQL 语句 格式 如 下 : 
BACKUP LOG 数据 库 名 TO DISK=' 地 址 \ 数 据 库 名 logl' 


@ 文件 组 备份 : 当 一 个 数据 库 很 大 时 ， 对 整个 数据 库 进 行 备份 可 能 会 花费 很 多 的 时 
间 ， 这 时 可 对 数据 库 中 的 部 分 文件 或 文件 组 进行 备份 。 

(2) 恢复 模型 。 

G@ 简单 恢复 模型 ， 使 用 数据 库 的 完全 备份 和 差异 备份 ， 但 无 法 将 数据 库 恢复 到 故障 
点 或 特定 检查 点 ， 一 般 对 不 经 常 更 新 数据 的 小 型 数据 库 使 用 。 

@ 完全 恢复 模型 : 默认 的 恢复 模型 ， 使 用 数据 库 备 份 和 日 志 备份 ， 可 以 将 数据 库 恢 
复 到 故障 点 ， 在 故障 还 原 中 具有 最 高 的 优先 级 。 

@ 大 容量 日 志 恢 复 模型 :与 完全 恢复 模型 相似 ， 在 这 种 模型 下 ， 日 志 只 记录 多 个 操 
作 的 最 终结 果 ， 而 非 存 储 操作 的 过 程 细 节 ， 因 此 日 志 尺寸 更 小 ， 大 批量 操作 的 速度 更 快 。 
如 果 日 志 没有 受到 破坏 ， 除 了 故障 期 间 发 生 的 事务 以 外 ， 能 够 还 原 全 部 数据 。 但 由 于 使 用 
最 小 日 志 的 方式 记录 事务 ， 所 以 不 能 恢复 数据 库 到 特定 的 时 间 点 。 


五 、 实 验 步骤 


进行 数据 备份 的 一 种 常用 方法 是 将 数据 库 直 接 复 制 出 来 ,在 必要 的 时 候 再 附加 到 SQL 
Server 系统 中 ， 与 操作 系统 复制 命令 不 同 的 是 ， 此 处 在 复制 前 需 先 进行 数据 库 的 分 离 。 分 
离 数据 库 的 目的 是 将 指定 的 数据 库 从 SQL Server 中 外 载 , 就 如 同 SQL Server 中 从 来 没有 存 
1. 分 离 数据 库 


(1) 打开 SQL Server Management Studio， 在 对 象 资源 管理 器 中 展开 “数据 库 ” 节 点 ， 
找到 准备 分 离 的 数据 库 ， 右 击 鼠 标 ， 在 弹出 的 快捷 菜单 中 选择 “任务 ”一 “分 离 ” 如 
图 4-34 所 示 。 

(2) 在 弹出 的 “分 离 数 据 库 ” 对 话 框 中 ， 单 击 “ 确 定 ” 按 钮 开始 分 离 工 作 ， 完 成 分 离 
后 系统 给 出 工作 完成 的 提示 ， 被 分 离 的 数据 库 也 从 服务 器 中 删除 。 

2. 附加 数据 库 


(1) 打开 SQL Server Management Studio， 在 对 象 资源 管理 器 中 选择 “数据 库 ”， 右 击 鼠 
标 ， 在 弹出 的 快捷 菜单 中 选择 “附加 ” 如 图 4-35 所 示 。 























a me 
日 图 LG21505\SQLSEVER (SQL Server 11.0.3000 - LG21: 
日 向 欢 捞 库 











日 图 LG21505\SQLSEVER (SQL Server 11.0.3000 - LG2150: 








图 4-34 选择 “分 离 ” 命 令 图 4-35 选择 “附加 ”命令 


第 4 章 ”课程 实验 *。89 。 


(2) 在 弹出 的 “附加 数据 库 ” 对 话 框 中 (如 图 4-36 所 示 )， 单 击 “ 添 加 ”按钮 ， 在 弹出 的 
“定位 数据 库 文 件 ” 对 话 框 中 选择 需要 附加 的 数据 库 文件 名 及 位 置 。 选 择 完毕 ， 单 击 “ 确 定 ” 
按钮 。 系 统 自 动 将 数据 附加 到 SQL Server 中 ， 被 附加 的 数据 库 显示 在 对 象 资源 管理 器 中 。 





eo 






0 
奈 析 文件 名 文件 类 型 当 阐 文件 了 位 





图 4-36 “附加 数据 库 ” 对 话 框 


3. 备份 数据 库 


(1) 打开 SQL Server Management Studio， 在 对 象 资源 管理 器 中 展开 “数据 库 ” 节 点 ， 
找到 准备 备份 的 数据 库 ， 右 击 鼠 标 ， 在 弹出 的 快捷 菜单 中 选择 “任务 ”一 “备份 ”。 

(2) 弹出 “备份 数据 库 ” 对 话 框 ， 先 单 击 “ 删 除 ”按钮 ， 然 后 在 “备份 类 型 ”下 拉 框 
中 选择 备份 类 型 (默认 为 完整 备份 )， 在 “名 称 ” 文 本 框 中 输入 备份 名 称 ， 设 置 完毕 单 击 “ 添 
加 ”按钮 ， 如 图 4-37 所 示 。 
G3) 在 弹出 的 “选择 备份 目标 ”对 话 框 中 单 击 鸭 ， 然 后 设置 备份 路 径 和 备份 文件 名 ， 
单 击 “ 确 定 ”” 即 可 完成 数据 库 备份 操 作 ， 如 图 4-38 所 示 。 
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图 4-37 数据 库 备份 设置 图 4-38 选择 备份 目标 


4. 还 原 数据 库 


(1) 打开 SQL Server Management Studio， 在 对 象 资源 管理 器 中 展开 “数据 库 ” 节 点 ， 
找到 准备 还 原 的 数据 库 ， 右 击 鼠 标 ， 在 弹出 的 快捷 菜单 中 选择 “任务 ”一 “还 原 ” 一 “ 数 
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据 库 ”。 

(2) 弹出 “还 原 数据 库 ” 对 话 框 ， 选 择 “ 设 备 ”， 然 后 单 击 后 面 的 国 | 按钮， 弹出 “ 先 
择 备份 设备 ”对 话 框 ， 如 图 4-39 所 示 。 单 击 “ 添 加 ”按钮 ， 在 “定位 备份 文件 ”对 话 框 中 
找到 数据 库 备份 的 路 径 ， 选 择 要 还 原 的 数据 库 ， 单 击 “ 确 定 ”。 
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图 4-39 “选择 备份 设备 ”对 话 框 
(3) 弹出 “还 原 数据 库 ” 对 话 框 ， 勾 选 “要 还 原 的 备份 集 ” 下 的 数据 库 前 的 复 选 框 ， 
如 图 4-40 所 示 。 然 后 选择 “选择 页 ” 窗 格 中 的 “选项 ”， 勾 选 “ 覆 盖 现 有 数据 库 ” 如 
图 4-41 所 示 。 单 击 “ 确 定 ” 系统 自动 进行 数据 库 还 原 操作 。 



















数据 让 (8): StudScore_DB 
还 大 到 (R): 上 次 执行 的 备份 (2018 年 3 月 29 日 16:43:47) 时间 续 O… 











还 要 组 件 类 型 “服务 器 施放 计 第 一 个 LSN 
| 回 | sudscore pe- 320 政和 充 妈 L621505\SQLSEVER StudScore DB 1 。 38000000006 








| 连接 
对 LG21505\SQLSEVER 
[LG21505Administrator] 


| 上 


ESE 









































图 4-40 勾 选 要 还 原 的 备份 集 
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保守 所 寺 设置 (WITH KEEP_REPLICATION)B) 
目 限制 访问 还 原 的 数据 检 (WITH RESTRICTED_USERJIB) 





雇 香 状 志 回 : [RESTORE WITH RECOvERY = 





备用 文件 (S): DAProgram Files\Microsoft SQL Server\MSSQLILSQLS|| 
通过 同 计 未 坦 交 的 各 务 ， 使 天 手相 于 可 以 使 用 的 状 志 。 无 法 下 穆 忆 他 事务 日 去- 





结尾 日 志 备 份 
园 还 项 晶 进行 结尾 日 志 备 份 CD 
保持 源 炊 插 库 处 于 正在 还 原状 态 

区 wrr NoRECovERVOU 


备份 文件 (8)}: Diprogram Files\Microsoft SQL ServerMSSQLILSQLSI 





连接 | 
对 LG21505\SQLSEVER 
[LG21505Wdministratorl 日 关闭 到 目标 数据 亩 的 现 有 连 亦 (C) 





二 下 注 二 作 
进度 | 


Pr 






































图 4-41 勾 选 “ 荐 着 现 有 数据 库 ” 
六 、 实 验 报告 要 求 

实验 报告 必须 附 实验 结果 的 截图 ， 以 及 实验 结果 的 分 析 。 
七 、 思 考题 


(1) 数据 库 进 行 数据 备份 ， 有 哪 几 种 方法 ? 各 有 什么 优 缺 点 ? 
(2) SQL Server 中 数据 备份 和 数据 恢复 功能 如 何 ? 有 哪些 不 足 之 处 ? 
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第 5 章 课程 设计 概述 
第 6 章 课程 设计 规范 
第 7 章 课程 设计 大 纲 
第 8 章 课程 设计 实施 方案 
第 9 章 课程 设计 实例 
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5.1 课程 设计 的 特性 


1. 课程 设计 是 有 目的 性 的 

课程 设计 不 仅仅 只 “涉及 ”学 习 的 学 科 ， 其 更 重要 的 目的 是 改进 学 生 的 学 习 ， 也 可 以 
有 其 他 目的 。 无 论 这 些 目的 是 协调 一 致 的 还 是 有 冲突 的 ， 明 确 的 还 是 含蓄 的 ， 当 前 的 还 是 
长 远 的 ， 课 程 设计 人 员 都 要 尽 可 能 地 识别 什么 是 真正 的 目的 ， 这 样 才能 找 出 相应 的 答案 。 

2. 课程 设计 是 审慎 的 

课程 设计 不 能 是 随意 的 、 无 计划 的 ， 也 不 是 几 周 、 几 个 月 和 几 年 内 课程 众多 变动 的 总 
和 。 课 程 设 计 要 有 效 ， 必 须 是 一 项 有 目的 的 规划 工作 。 它 需要 有 明确 的 工作 程序 ， 确 定 应 
做 什么 、 由 谁 来 做 和 什么 时 候 做 。 

3. 课程 设计 应 是 有 创造 性 的 

完好 的 课程 设计 是 系统 又 具有 创造 性 的 ， 既 要 脚踏实地 又 要 富有 想象 力 。 课 程 设计 不 
是 一 个 简单 划一 的 过 程 ， 课 程 设计 的 每 一 步 都 有 机 会 提出 创造 性 的 见解 和 办 新 的 理念 ， 开 
展 创造 性 的 工作 。 

4. 课程 设计 在 多 层次 上 运作 

一 个 层次 的 设计 决策 必须 同 其 他 层次 的 决定 协调 一 致 。 

5. 课程 设计 要 有 折 中 妥协 

制定 达到 复杂 规范 的 设计 ， 必 然 要 在 效益 、 成 本 、 限 制 条 件 和 风险 之 间 进 行 权衡 。 无 
论 规划 如 何 系统 ， 想 法 如 何 具有 创造 性 ， 任 何 课程 设计 都 不 能 满足 人 们 的 每 个 要 求 。 运 转 
良好 的 课程 也 会 遇 到 挑战 ， 因 此 课程 设计 要 有 所 折 中 妥协 。 

6. 设计 也 会 失败 

一 项 设计 的 失败 可 能 是 因为 它 的 一 个 或 几 个 组 成 部 分 失败 了 ， 或 因为 各 组 成 部 分 组 合 
在 一 起 不 能 很 好 地 运转 ， 也 可 能 是 由 于 实施 设计 方案 的 人 误解 了 设计 或 不 喜欢 设计 方案 ， 
他 们 拒绝 了 设计 方案 。 课 程 设计 没有 顺利 实行 有 很 多 方面 的 原因 ， 多 数 情况 是 设计 不 完全 
令 人 满意 , 并 不 是 彻底 失败 。 调 和 设计 的 关键 是 在 设计 过 程 中 和 设计 后 能 继续 完善 和 改进 。 
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7. 课程 设计 应 是 有 步骤 的 


在 设计 工作 中 ， 识 别 每 阶段 不 同 的 任务 和 问题 是 重要 的 。 课 程 设 计 是 系统 地 执行 规划 
指令 的 一 种 保证 ， 虽 然 它 并 没有 规定 严格 的 顺序 和 不 能 变动 的 步 又。 可 是 ， 课 程 设计 在 一 
个 阶段 的 决定 并 不 能 独立 于 其 他 阶段 的 决定 ， 所 以 课程 设计 的 过 程 会 有 反复 ， 需 要 回顾 和 
重新 审议 ， 做 必要 的 修改 。 其 步骤 如 下 : 制定 课程 设计 的 规范 ， 形 成 课程 设计 的 理念 ， 编 
制 课程 设计 和 完善 课程 设计 。 


5.2 ”制定 课程 设计 规范 


设计 工作 往往 是 从 面临 的 “问题 ”出 发 ， 即 要 用 有 限 的 手段 去 做 好 工作 。 目 标 是 设计 
能 达到 的 要 求 和 特点 。 如 果 我 们 不 能 确定 目标 究竟 是 什么 ， 我 们 就 不 可 能 知道 我 们 是 否 能 
完成 它 。 限 制 条 件 是 设计 过 程 中 我 们 难以 避免 的 制约 因素 ， 有 物质 的 、 经 济 的 、 政 治 的 或 
法 律 的 。 忽 视 课程 设计 限制 条 件 的 最 终结 果 可 能 无 法 想象 。 一 项 课程 设计 方案 的 成 功 与 否 ， 
很 大 程度 上 取决 于 目标 是 否 规定 得 明确 ， 是 否 承认 限制 条 件 。 





5.3 ”课程 设计 的 课程 目标 


学 校 教育 是 期 望 在 青年 人 迈 向 成 年 人 的 道路 上 培养 他 们 具有 健康 的 、 强 烈 的 社会 责任 
感 ， 是 要 培养 学 生 具 有 公民 的 品德 ， 为 他 们 将 来 工作 做 准备 ， 培 育 他 们 的 素养 和 鼓励 他 们 
独特 的 兴趣 和 才能 。 因 此 ， 课 程 设计 显得 格外 重要 。 

在 描述 一 门 课程 时 ， 第 一 个 要 求 是 应 明确 预期 要 达到 的 目标 。 严 格 地 说 ， 目 标本 来 不 
是 课程 的 一 部 分 ， 目 标 是 目的 ， 而 课程 是 手段 ， 两 者 不 能 混淆 。 

课程 设计 要 取得 进展 ， 就 必须 把 注意 力 集中 在 确定 那些 可 靠 又 可 行 的 学 习 目 标 上 。 要 
正确 地 做 到 这 点 ， 就 要 处 理 好 困难 的 问题 。 困 难 包 括 投资 、 理 由 、 具 体 说 明 、 可 行 性 。 














5.4 ”课程 设计 的 限制 条 件 


制定 课程 设计 规范 的 另 一 方面 问题 是 认识 影响 设计 的 限制 条 件 。 设 计 总 会 有 限制 条 
件 ， 它 们 表现 的 方式 可 能 是 不 允许 做 某 些 事 或 必须 考虑 某 种 条 件 。 如 同 目标 一 样 ， 事 先 应 
搞 清楚 限制 条 件 ， 因 为 它们 会 影响 课程 设计 。 

达到 课程 目标 的 主要 障碍 是 缺乏 足够 时 间 进 行 教学 ， 而 课程 期 望 能 达到 的 目标 越 来 越 
多 。 如 实地 承认 这 种 限制 导致 了 目标 之 间 的 冲突 ， 要 达到 某 些 目标 就 得 放弃 其 他 目标 。 除 
时 间 限 制 以 外 ， 还 有 公众 认可 的 问题 、 学 生 的 学 习 情况 等 。 
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为 了 避 开 已 经 认识 到 的 障碍 而 减少 目标 的 方法 是 不 可 行 的 。 客 观 上 的 限制 条 件 是 会 
着 时 间 的 推移 而 改变 的 。 除 物质 定律 外 ， 制 约 因 素 不 一 定 会 长 期 存在 ， 会 随 着 时 间 的 推移 
而 发 生 改变 。 因 此 ， 既 不 要 忽视 制约 因素 ， 也 不 要 认为 那 是 不 可 逾越 的 因素 。 

在 设计 过 程 中 ， 任 何 阶段 都 会 遇 到 限制 条 件 ， 重 要 的 是 查 明 在 处 理 限 制 条 件 上 有 多 大 
的 自由 。 另 一 个 处 理 制约 条 件 的 办 法 是 在 设计 方案 中 增加 一 个 在 实验 设计 的 课程 以 后 改善 
限制 条 件 的 步骤 。 














5.5 形成 课程 设计 理念 


一 些 对 课程 至 关 重要 的 观念 是 形成 设计 理念 的 起 点 ， 它 也 许 只 是 一 些 印象 而 并 不 真 
实 ， 但 对 课程 设计 是 有 价值 的 ， 在 探讨 可 供 选择 的 设计 时 可 以 作为 参考 。 各 种 可 能 性 都 是 
存在 的 ， 课 程 理 念 一 般 应 包括 须 强调 的 教学 内 容 条 件 、 使 用 的 教学 方法 和 可 利用 的 资源 。 

设计 理念 可 以 用 许多 种 方法 来 表述 ， 如 一 览 表 和 文字 的 描述 、 略 图 和 其 他 图 解 、 模 
型 或 有 吸引 力 的 实例 报告 。 对 课程 设计 来 说 ， 至 少 需要 一 个 简要 的 说 明 来 阐明 课程 有 什 
么 特点 。 
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6.1 课程 设计 工作 规范 


第 一 条 ”课程 设计 是 根据 专业 教学 计划 和 课程 教学 目标 的 要 求 ， 将 一 门 或 几 门 课程 中 
有 关 知 识 综合 应 用 ， 对 本 科学 生 进行 设计 思想 和 设计 方法 的 初步 训练 ， 使 学 生 掌 握 基本 研 
究 设 计 方法 的 教学 活动 。 课 程 设计 (论文 (以 下 简称 “课程 设计 ”) 是 教学 计划 中 的 重要 环节 
之 一 ， 是 实践 教学 环节 的 重要 组 成 部 分 ， 是 培养 学 生 创 新 设计 能 力 的 重要 基础 。 为 规范 管 
理 ， 保 证 课程 设计 落 到 实处 ， 结 合 学 院 实际 制定 本 规范 。 

第 二 条 ”课程 设计 的 教学 目标 

1. 培养 学 生理 论 联系 实际 的 作风 、 求 真 务实 的 科学 态度 和 勇于 探索 的 创新 精神 。 

2. 帮助 学 生 深入 理解 和 牢固 掌握 所 学 课程 的 知识 和 技能 ， 提 高 解决 实际 问题 的 能 力 ， 
初步 体验 工程 项 目的 设计 过 程 ， 在 实践 中 提升 自身 的 工程 素质 。 

3. 使 学 生 了 解 相关 的 设计 标准 、 规 范 和 程序 ， 初 步 掌握 科学 的 设计 方法 和 手段 ， 正 确 
掌握 和 使 用 设计 工具 。 

4. 培养 学 生 获取 信息 和 综合 处 理 信息 的 能 力 ， 提 高 文字 和 语言 表达 能 力 。 

第 三 条 ”课程 设计 的 教学 要 求 

1. 紧密 结合 相关 课程 教学 ， 加 强 基 本 功 训练 ， 注 重工 程 设 计 能 力 培养 。 

2. 做 到 理论 与 实际 相 结 合 ， 继 承 与 创新 相 结合 ， 教 师 因材施教 、 严 格 要 求 与 发 挥 学生 
主观 能 动 性 相 结合 。 

3. 学 生 要 认真 学 习 教材 和 相关 资料 ， 阅 读 有 关 规 范 和 资料 ， 独 立 按时 完成 任务 。 

4. 课程 设计 的 说 明 书 要 求 简洁 、 通 顺 、 计 算 正 确 ， 图 和 表 的 表达 内 容 完整 、 清 楚 、 
规范 。 

第 四 条 ”管理 职责 

1. 教务 处 负责 制订 相关 规范 ， 指 导 和 协调 全 校 各 专业 的 课程 设计 工作 。 

2. 各 院 系 可 根据 学 校规 范 制定 课程 设计 工作 细则 。 

3. 各 院 系 负责 本 单位 课程 设计 教学 环节 的 组 织 实 施 与 管理 工作 。 

4. 专业 教研 室 具 体 组 织 课程 设计 选 题 、 指 导 书 编写 、 项 目 过 程 检查 、 评 分 标准 制定 、 
考核 方式 审定 等 项 工作 。 

第 五 条 ”课程 设计 的 选 题 

1. 课程 设计 选 题 应 尽量 覆盖 课程 教学 的 主要 内 容 ,满足 课程 教学 大 纲 的 要 求 ， 达 到 课 
程 设 计 的 教学 目标 ， 使 学 生得 到 较 全 面 的 综合 训练 。 
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2. 选 题 的 深度 、 广 度 和 难 易 程度 适当 ， 使 学 生 在 计划 时 间 内 经 努力 能 够 完成 任务 。 

3. 课程 设计 题目 由 指导 教师 拟定 ， 并 经 院 系 审定 ， 题目 也 可 由 学 生 自 拟 ,但 须 报 学 院 
系 审批 同意 后 方 可 执行 。 

第 六 条 ”课程 设计 任务 书 、 指 导 书 

1. 课程 设计 任务 书 由 指导 教师 编写 ,教研室 主任 或 课程 负责 人 审定 , 布置 设计 任务 之 
前 印发 给 学 生 。 任 务 书 应 包括 设计 题目 、 目 的 与 要 求 、 主 要 任务 、 参 考 资料 等 内 容 。 

2. 指导 书 是 学 生 进 行 课程 设计 的 指导 性 文件 ， 应 包括 以 下 内 容 : 课程 设计 的 类 别 、 目 
的 、 内 容 ; 设计 步 又、 设计 要 点 ; 课程 设计 中 所 涉及 主要 技术 的 关键 性 分 析 和 解决 方案 等 。 

3. 不 同 专业 、 课 程 的 设计 任务 书 、 指 导 书 的 具体 格式 可 以 有 所 不 同 ， 由 教研 室 参考 附 
件 格 式 制定 。 

第 七 条 ”对 指导 教师 的 要 求 

1. 指导 教师 一 般 由 具有 中 级 以 上 职称 ， 且 通过 院 系 考核 的 教师 担任 。 每 位 指导 教师 指 
导 的 学 生 数 一 般 不 超过 一 个 自然 班 。 

2. 指导 教师 应 熟悉 课程 设计 的 理论 知识 ,根据 课程 设计 教学 大 纲要 求 拟 定 题目 、 任 务 
书 及 指导 书 ， 制 定 具体 考核 形式 并 事先 向 学 生 公 布 。 要 做 好 课程 设计 的 准备 工作 。 

3. 按照 教学 大 纲 的 要 求 ， 贯 彻 因材施教 的 原则 ， 注 重启 发 引导 ， 鼓 励 学 生 提出 独立 见 
解 ， 适 当 组 织 讨 论 ， 充 分 发 挥 学 生 的 主体 作用 ， 注 意 开 发 学 生 的 创新 潜能 。 

4. 培养 和 帮助 学 生 确 立正 确 的 设计 思想 ， 提 高 分 析 问 题 和 解决 问题 的 能 力 ， 培 养 严谨 
的 科学 态度 和 良好 学 风 。 

5. 严格 要 求 ， 课 程 设 计 教学 要 认真 布置、 检查 和 严格 考核 ， 促 使 学 生 独 立 完 成 设计 
任务 。 

6. 在 课程 设计 过 程 中 ,教师 要 按时 到 场 做 具体 指导 ， 及 时 发 现 并 解决 问题 ， 督 促 课 程 
设计 的 进度 和 质量 。 

7. 课程 设计 结束 后 要 做 好 工作 总 结 ， 按 规定 保管 或 上 交 文 档 和 电子 资料 。 

第 八条 ”对 学 生 的 要 求 
. 学 生 应 当 修 完 课程 设计 的 先 修 课 程 再 进行 课程 设计 。 
. 学 生 应 当 明 确 课程 设计 的 目的 和 重要 性 ， 积 极 认真 地 做 好 准备 工作 。 
. 学 生 应 当 在 教师 指导 下 ， 在 规定 的 时 间 内 独立 完成 设计 任务 。 
. 课程 设计 期 间 学 生 的 考勤 与 纪律 按 学 生 考 勤 管理 办 法 执行 。 

5. 课程 设计 期 间 要 爱护 公物 、 搞 好 环境 卫生 ， 保 证 实验 室 整洁 、 文 明 、 安 静 。 严 禁 在 
实验 室内 嬉戏 或 开展 其 他 休闲 娱乐 活动 。 

6. 如 有 抄 秦 或 找 人 代 做 等 舞 潍 行为 ， 一 经 发 现成 绩 记 零 分 ， 并 按 考 试 作 次 处 理 。 

第 九条 ”成 绩 评定 

1. 作品 和 设计 报告 完成 情况 ,独立 工作 能 力 及 设计 过 程 的 表现 ,考勤 和 回答 问题 的 情 
况 等 是 成 绩 评定 的 基本 依据 。 各 部 分 评分 权重 由 各 院 系 根据 专业 特点 自行 确定 。 

2. 课程 设计 的 成 绩 分 为 优秀 、 良 好 、 中 等 、 及 格 、 不 及 格 五 个 等 级 ， 评 为 优秀 的 人 数 
一 般 不 超过 15%， 优 良 的 比例 一 般 不 超过 65%。 





全- 
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第 十 条 “课程 设计 的 文档 资料 由 院 系 保留 至 学 生 毕 业 后 两 年 ， 对 于 有 示范 意义 的 优秀 
课程 设计 作品 及 设计 报告 应 长 期 保存 。 

第 十 一 条 各 院 系 可 根据 具体 情况 制定 相应 的 实施 细则 。 

第 十 二 条 ”本 规定 自 X X 年 修订 之 日 起 实行 ， 由 教务 处 负责 解释 ， 此 前 相关 规定 同时 
废止 。 




















6.2 ”课程 设计 (论文 ) 撰 写 规范 


为 了 统一 规范 课程 设计 的 格式 ， 保 证 课程 设计 的 质量 ， 便 于 信息 系统 的 收集 、 存 储 、 
处 理 、 加 工 、 检 索 、 利 用 、 交 流 、 传 播 ， 根 据 国 家 标准 局 批准 颁发 的 GB 7713-1987《 科 学 
技术 报告 、 学 位 论文 和 学 术 论文 的 编写 格式 》， 特 制定 本 要 求 。 

1. 课程 设计 (论文 ) 规 范 

1.1 课程 设计 (论文 ) 用 纸 、 页 眉 、 页 边 距 、 字 间距 和 行 间距 

(1) 课程 设计 (论文 ) 用 纸 一 律 为 A4， 单 面 打印 。 

(2) 页 眉 : 从 正文 开始 到 最 后 ， 在 每 一 页 的 最 上 方 ， 用 5 号 宋体 ， 居 中 排列 ， 页 眉 之 
下 划一 条 0.75 磅 线 ， 页 眉 用 论文 的 名 称 。 

(3) 页 边 距 、 字 间距 和 行 间距 : 页 边 距 (上 下 ): 2.54 cm; (左右 ): 3.17 cm; 字 间 距 : 标 
准 ， 小 四 号 字 ;， 行 间距 ，1.5 倍 行距 。 

(4) 课程 设计 (论文 ) 一 律 使 用 简化 汉字 ,全 部 打印 清楚 ， 少 量 中 、 英 文 无 法 打印 的 文字 
符号 可 允许 手写 ， 但 须 清 晰 整洁 。 

1.2 课程 设计 (论文 ) 顺 序 

课程 设计 (论文 顺序 依次 为 封面 、 中 文摘 要 、 英 文摘 要 、 目 录 、 主 要 符号 表 、 正 文 、 
参考 文献 、 附 录 、 致 谢 。 主 要 符号 表 和 附录 可 按 需 列 入 。 

(1) 封面 

课程 设计 (论文 封面 内 容 :学校 代 码 、 学 号 、 学 校 名 称 、 院 系 名 称 、 课 程 设计 题目 
专业 (二 级 学 科 名 称 )、 本 人 姓名 、 指 导 教 师 ( 姓 名 、 职 称 )、 完 成 年 月 。 

注 : 论文 封面 学 院 统一 制作 。 论 文 题目 字数 一 般 应 在 25 字 以 内 。 

论文 书 脊 上 写 明 : 论文 题目 、 姓 名 、 课 程 设 计 ( 论 文 ) 年 份 (用 中 文 )。 

(2) 中 文摘 要 

中 文摘 要 200 一 400 字 。 论 文摘 要 一 般 包括 : 论文 的 目的 和 重要 性 ， 完成 了 哪些 工作 ; 
获得 的 主要 结论 。 论 文 应 突出 理论 与 实践 的 结合 点 ， 用 句 应 精炼 概括 ， 并 有 本 论文 的 关键 
词 3~5 个 ， 关键 词 应 从 《汉语 主题 词 表 》 中 摘 选 ， 当 《汉语 主题 词 表 》 的 词 不 足以 反映 主 
题 时 ， 可 由 作者 设计 关键 词 。 中 外 文摘 要 及 关键 词 分 置 两 页 。 

(3) 英文 摘要 

@ 用 词 应 准确 ， 使 用 本 学 科 通 用 的 词汇 。 

@ 摘要 中 主语 (作者 ) 常 常 省 略 ， 因 而 一 般 使 用 被 动 语 态 ， 应 使 用 正确 的 时 态 并 要 注意 
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主 、 谓 语 的 一 致 性 。 必 要 的 冠 词 不 能 省 略 。 

@ 关键 词 (Key words) 按 相应 专业 的 标准 术语 写 出 。 

@ 中 、 英 文摘 要 的 内 容 须 一 致 。 

(4) 目录 

@ 目录 中 章 、 节 号 均 使 用 阿拉 伯 数 字 ， 如 第 1 章 则 为 1， 其 余 分 层次 为 1.1 及 1.1.1 
等 几 个 层次 ， 其 中 “ "用 半角 。 

@ 目录 中 应 有 页 号 ， 页 号 从 正文 开始 直到 全 文 结束 。 

@ 目录 页 号 另 编 。 

@ 页 号 在 页 下 方 中 间 排列 。 

(5) 主要 符号 表 

@ 全 文中 常用 的 符号 及 意义 在 主要 符号 表 中 列 出 。 

@ 符号 排列 顺序 按 英文 及 其 他 相关 文字 顺序 排出 。 

@ 主要 符号 表 页 号 另 编 。 

1.3 课程 设计 (论文 ) 正 文 的 规范 

正文 是 一 个 逻辑 严密 、 论 述 准 确 、 结 构 合理 、 内 容 充 实 的 整体 ,一 般 应 包括 研究 背景 、 
主体 研究 内 容 及 过 程 、 结 论 等 部 分 。 作 者 可 视 具体 研究 内 容 分 为 若干 章 。 全 文 应 与 参考 文 
献 紧密 结合 ， 重 点 论述 作者 本 人 的 独立 研究 工作 和 创造 性 见解 。 参 考 或 引用 他 人 的 学 术 成 
果 或 学 术 观 点 ， 必 须 给 出 参考 文献 ， 严 禁 抄袭 、 占 有 他 人 的 成 果 。 

1.3.1 研究 背景 及 意义 

论文 的 研究 背景 是 整个 论文 的 基础 ， 研 究 背 景 及 意义 的 内 容 和 要 求 如 下 。 

(1) 清楚 、 严 谨 地 论述 国内 外 关于 本 领域 的 研究 现状 、 水 平 及 存在 的 问题 。 

(2) 阐述 本 研究 与 现实 的 联系 。 

(3) 明确 论述 本 研究 的 目的 及 其 意义 。 

(4) 阐述 本 论文 的 研究 思路 和 主要 内 容 。 

1.3.2 课程 设计 (论文 ) 的 主体 研究 内 容 

论文 的 主体 研究 内 容 及 规范 由 各 专业 根据 专业 特点 确定 。 

1.3.3 结论 

结论 要 求 简明 扼要 地 概括 全 部 论文 所 得 的 若干 重要 结果 ， 着 重 介绍 本 人 的 独立 研究 和 
创造 性 成 果 及 其 在 本 学 科 领 域 中 的 地 位 和 作用 。 用 词 要 准确 、 精 练 、 实 事 求 是 。 

1.3.4 插图、 表格 、 公 式 

(1) 插图 

@ 所 有 插图 按 分 章 编号 , 如 第 1 章 的 第 1 张 插图 为 “图 1-1” 所 有 插图 均 需 有 图 题 (图 
的 说 明 )， 图 号 及 图 题 应 在 图 的 下 方 居中 标 出 。 

@ 一 幅 图 如 有 若干 幅 分 图 ， 均 应 编 分 图 号 ， 用 (a)，(b)，(c)…… 按 顺序 编排 。 

@ 插图 须 紧 跟 文 述 ， 在 正文 中 ， 一 般 应 先 见 图 号 及 图 的 内 容 后 再 见 图 ， 一 般 情况 下 
不 能 提前 见 图 ， 特 殊 情 况 需 延 后 的 插图 不 应 跨 节 。 

@ 图 形 符号 及 各 种 线 型 画 法 须 按照 现行 的 国家 标准 。 
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@ 华 标 图 中 坐标 上 须 注 明 标 度 值 ， 并 标明 坐标 轴 所 表示 的 物理 量 名 称 及 量 纲 ， 应 均 
按 国 际 标准 (SD) 标 注 ， 例 如 : kW，m/s，N，m 等 ， 但 对 一 些 示 意图 例外 。 

@ 图 应 具有 “自明 性 ”， 即 只 看 图 、 图 题 和 图 例 ， 不 阅读 正文 ， 就 可 理解 图 意 。 

@ 图 中 用 字 最 小 为 小 五 号 字 。 

@ 使 用 他 人 插图 须 在 图 题 正 下 方 注 明 出 处 。 

(2) 表格 

Q 表格 应 按 章 编号 ， 如 表 2-1， 并 需 有 表 题 。 

@ 表 号 、 表 题 置 表格 上 方 并 与 表 居 中 对 齐 排列 。 

@ 表格 的 设计 应 紧 跟 文 述 ， 若 为 大 表 或 作为 工具 使 用 的 表格 ， 可 作为 附 表 在 附录 中 























仆 
压 


@ 表 中 各 物理 量 及 量 纲 均 按 国际 标准 (SD 及 国家 规定 的 法 定 符号 和 法 定 计量 单位 标注 。 
@ 使 用 他 人 表格 须 在 表格 下 方 注 明 出 处 。 
(3) 公式 
@ 公式 均 需 有 公式 号 。 
@ 公式 号 按 章 编排 ， 如 式 (2-3)。 
@ 公式 中 各 物理 量 及 量 纲 均 按 国际 标准 (SD 及 国家 规定 的 法 定 符号 和 法 定 计 量 单位 
标注 ， 禁 止 使 用 已 废弃 的 符号 和 计量 单位 。 

@ 公式 中 用 字 、 符 号 、 字 体 要 符合 学 科 规 范 。 

1.3.5 ”参考 文献 

(1) 参考 文献 一 般 应 是 作者 亲自 考察 过 的 对 课程 设计 有 参考 价值 的 文献 ， 除 特殊 情况 
外 ， 一 般 不 应 间接 使 用 参考 文献 。 

(2) 参考 文献 应 具有 权威 性 ， 要 注意 引用 最 新 的 文献 。 

(3) 引用 他 人 的 学 术 观 点 或 学 术 成 果 ， 必 须 列 在 参考 文献 中 。 

(4) 参考 文献 在 整个 论文 中 按 出 现 次 序 依次 列 出 ， 并 在 引用 处 右上 角 标 注 ， 标 注 符号 
为 【X】。 

(5) 参考 文献 的 数量 一 般 不 低 于 20 篇 ， 以 近期 文献 为 主 ;， 引 用 的 文献 必须 有 外 文 文献 
(不 含 中 文 译本 )， 外 语 专业 必须 有 本 专业 语种 以 外 的 外 文 文献 。 

(6) 参考 文献 的 书写 顺序 按照 论文 中 出 现 的 先后 排列 。 参 考 文献 的 著录 格式 如 下 。 

@ 期 刊 的 著录 格式 : 序号 作者 . 题名 . 刊 名 (外 文 刊 名 可 缩写 ， 缩 写 后 的 首 字母 应 大 
写 )， 出 版 年 ， 卷 号 (期 号 ): 页 码 (起 始 页 ). 

@ 专著 的 著录 格式 :序号 作者 . 书 名 . 版 次 (第 一 版 不 标注 ) 出 版 地 : 出 版 者 ,出 版 年 . 
页 码 . 

@ 论文 集 的 著录 格式 : 序号 作者 . 题名 . 见 (In): 论文 集 主编 , 编 (eds). 论文 集 名. 出 
版 地 : 出 版 社 ， 出 版 年 . 页 码 . 

@ 课程 设计 的 著录 格式 : 序号 作者 . 题名 : [课程 设计 ]. 学 位 授予 单位 所 在 地 : 学 位 
授予 单位 , 学 位 授予 年 . 
@ 专利 的 著录 格式 : 序号 专利 申请 者 . 专利 题名 . 专利 国 别 , 专利 文献 种 类 , 专利 号 . 
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出 版 日 期 . 
@ 技术 标准 的 著录 格式 : 序号 技术 标准 发 布 单位 . 技术 标准 代号 . 技术 标准 名 称 . 出 
版 地 : 出 版 者 , 出 版 年 . 

1.4 课程 设计 (论文 ) 的 附录 

附录 的 内 容 包 括 : 

(1) 正文 中 过 长 的 公式 推导 与 证 明 过 程 ， 可 在 附录 中 依次 给 出 。 

(2) 与 本 文 紧密 相关 的 非 作 者 自己 的 分 析 、 证 明 及 工具 用 表格 等 。 

(3) 在 正文 中 无 法 列 出 的 实验 数据 。 

1.5 致谢 

致谢 中 主要 感谢 导师 和 对 论文 工作 有 直接 贡献 及 帮助 的 人 士 和 单位 。 谢 辞 谦虚 诚恳 ， 
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6.3 ”设计 报告 参考 模板 











xX XX 大 学 


课程 设计 
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摘 要 (黑体 3 号 、 居 中 ) 


摘要 内 容 ， (小 四 、 宋 体 1. 5 倍 行距 ， 首 行 缩 进 2 字符 ) 
【关键 词 】(3-5 个 、 小 四 、 黑 体 ) 


Abstract (Times New Roman，3 号 、 居 中 、 加 粗 ) 


外 文摘 要 内 容 与 中 文摘 要 对 应 : (小 四 、Times New Roman 字体 ，1.5 倍 
行距 ) 


【Key Words】(3~5 个 、 小 四 、Times New Roman 字体 ) 





*。106 。 数据 库 系统 原理 及 应 用 课程 设计 与 实验 指导 


目录 (黑体 3 号 、 居 中 ) 


1( 小 4 号 、 黑 体 ， 行 距 1.5 倍 ) 
1.1( 小 4 号 、 宋 体 ) 
1.1.1( 小 4 号 、 宋 体 ) 
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(正文 ) 大 标题 (第 1 章 ) (黑体 小 三 号 、 居 中 ) 


一 级 节 标 题 (1.1) 黑 体 四 号 


二 级 节 标 题 (1.1.1) 黑 体 小 四 号 

正文 宋体 小 四 号 ， 正 文 段落 和 标题 都 是 1.5 倍 行距 ， 正 文 段落 首 行 缩 进 
2 字符 

页 码 从 正文 开始 ， 在 页 下 方 中 间 排列 ， 宋 体 5 号 

页 蛋 从 正文 开始 ， 页 眉 用 论文 题目 、 居 中 、 宋 体 5 号 、 下 划 线 





附 录 ( 黑 体 3 号 、 居 中 ) 


内 容 (小 四 、 宋 体 、 行 距 1.5 倍 ) 

附录 的 内 容 包括 : 

(1) 正文 中 过 长 的 公式 推导 与 证 明 过 程 ， 可 以 在 附录 中 依次 给 出 。 
(2) 与 本 文 紧密 相关 的 非 作 者 自己 的 分 析 、 证 明 及 工具 用 表格 等 。 
G) 在 正文 中 无 法 列 出 的 实验 数据 。 


参考 文献 (黑体 3 号 、 居 中 ) 
文献 按照 论文 中 出 现 的 先后 顺序 排列 ， 文 献 参 考量 一 般 不 低 于 20 篇 ( 课 
程 设计 可 以 5 篇 以 上 ， 论 文 须 10 篇 以 上 ， 毕 业 论 文 应 20 篇 以 上 )。 
内 容 (小 四 、 宋 体 、 行 距 1.5 倍 ) 


致谢 (黑体 3 号 、 居 中 ) 


内 容 ( 小 四 、 宋 体 、 行 距 1.5 倍 、 首 行 缩 进 2 字符 ) 
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6.4 ”课程 设计 (论文 ) 任 务 书 


课程 设计 (论文 ) 任 务 书 


学 生 姓名 : 专业 班级 : 
指导 教师 : 工作 单位 : 


三 、 主 要 任务 : 
(包括 课程 设计 工作 量 及 其 技术 要 求 ， 以 及 说 明 书 撰写 等 具体 要 求 ) 


五 、 参 考 资料 : 





指导 教师 签名 : 











E 任 (或 责任 教师 ) 签 名 ; 
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“数据 库 系统 原理 及 应 用 ”课程 设计 教学 大 纲 


课程 代码 : xxx 课程 类 型 ， 纯 实践 课 
课程 名 称 : 数据 库 系统 原理 及 应 用 课程 性 质 ， 必修 
总 学 时 : 45 学 时 总 学 分 : 1.5 


适用 范围 :计算 机 科学 与 技术 、 网 络 工程 、 软 件 工程 


、 课 程 设 计 的 性 质 、 目 的 和 任务 


1. 课程 设计 的 性 质 

数据 库 系统 原理 及 应 用 课程 设计 是 实践 性 教学 环节 之 一 ， 是 “数据 库 系统 原理 及 
应 用 ”课程 的 辅助 教学 课程 。 通 过 课程 设计 ， 学 生 能 够 掌握 数据 库 的 基本 概念 ， 结 合 
实际 的 操作 和 设计 ， 巩 固 课堂 教学 内 容 ， 进 而 掌握 数据 库 系 统 的 基本 概念 、 原 理 和 技 
术 ， 将 理论 与 实际 相 结合 ， 应 用 现 有 的 数据 建 模 工具 和 数据 库 管理 系统 软件 ， 规 范 、 
科学 地 完成 一 个 小 型 数据 库 的 设计 与 实现 ， 把 理论 课 与 实验 课 所 学 内 容 做 一 个 综合 ， 
并 在 此 基础 上 强化 学 生 的 实践 意识 ， 提 高 其 实际 动手 能 力 和 创新 能 力 。 

2. 课程 设计 的 目的 和 任务 


数据 库 系统 原理 及 应 用 课程 设计 是 在 学 生 系统 地 学 习 “ 数 据 库 系统 原理 及 应 用 ” 
课程 后 ， 按 照 关 系数 据 库 的 基本 原理 ， 综 合 运 用 所 学 的 知识 ， 设 计 开 发 一 个 小 型 的 数 
据 库 管理 信息 系统 ， 使 学 生 掌 握 数 据 库 设 计 各 阶段 的 输入 、 输 出 、 设 计 环 境 、 目 标 和 
方法 , 熟练 掌握 两 个 主要 环节 一 一 概念 结构 设计 与 逻辑 结构 设计 ; 熟练 地 使 用 SQL 语 
言 实现 数据 库 的 建立 、 应 用 和 维护 。 通 过 对 一 个 实际 问题 的 分 析 、 设 计 与 实现 ， 将 原 
理 与 应 用 相 结 合 ， 学 会 如 何 把 书本 上 学 到 的 知识 用 于 解决 实际 问题 。 通 过 数据 库 课 程 
设计 ， 既 培养 学 生 的 动手 能 力 ， 又 能 使 学 生 深入 理解 和 灵活 掌握 教学 内 容 。 
二 、 课 程 设 计 的 基本 要 求 
1. 课程 设计 要 求 
课程 设计 的 基本 要 求 : 
(1) 学 生 自愿 分 组 ， 原 则 3~5 人 一 组 。 
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(2) 选 一 个 课程 设计 题目 ， 以 组 为 单位 完成 。 

(3) 课程 设计 时 间 为 1.5 周 。 

(4) 数据 库 管 理 系统 不 限 (SQL Server、MySQL、Oracle…)， 开 发 语言 不 限 (Java、 
C#、VC…)， 系 统 采用 C/S 模式 或 B/S 模式 均 可 。 

(5) 给 出 数据 库 设 计 各 个 阶段 的 详细 设计 报告 ， 各 个 阶段 都 要 有 相应 的 文档 ， 包 
括 需求 分 析 (系统 的 主要 功能 )、 概 念 结构 设计 、 逻 辑 结构 设计 、 物 理 结构 设计 、 软 件 
实现 等 ， 都 要 有 详细 的 计划 ， 设 计 文 档 应 按照 数据 库 设计 的 要 求 书写 。 

(6) 系统 中 的 数据 表 设 计 合 理 、 高 效 ， 尽 量 减 少数 据 元 余 ， 软 件 界 面 友好 、 健 康 。 

(7) 提交 运行 的 系统 。 

(8) 写 出 收获 和 体会 ， 包 括 已 解决 和 尚未 解决 的 问题 ， 进 一 步 完 善 设想 与 建议 。 

(9) 每 个 小 组 进行 报告 和 答辩 ， 讲 解 设计 方案 ， 演 示 系 统 运行 ， 汇 报 分 工 与 合作 
情况 。 

课程 设计 的 基本 要 求 还 包括 以 下 几 个 方面 。 

2. 选 题 和 系统 功能 要 求 

选 题 应 在 满足 教学 要 求 和 对 学 生 技 能 训练 的 前 提 下 ， 尽 可 能 结合 实际 需要 。 选 题 
的 难 易 程度 要 适当 ， 以 学 生 在 规定 时 间 内 经 过 努力 可 以 完成 为 宜 。 

系统 功能 要 求 根据 指导 教师 布置 的 题目 不 同 而 有 所 不 同 。 以 学 生 管理 系统 为 例 ， 
系统 的 基本 功能 可 要 求 如 下 。 

(1) 学 生 档 案 管理 : 提供 学 生 基本 信息 的 录入 和 修改 功能 ， 包 括 学 生 的 学 号 、 姓 
名 、 性 别 、 出 生日 期 、 入 学 日 期 、 专 业 、 班 级 等 学 生 的 个 人 基本 信息 。 

(2) 学 生 的 学 籍 管理 : 对 于 留级 、 体 学、 退学、 转学 的 学 生 学 籍 的 处 理 。 

(3) 选课 及 成 绩 管 理 : 简单 的 选课 和 成 绩 管 理 功能 。 

(4) 和 学 生 管理 有 关 的 其 他 模块 : 本 部 分 内 容 可 根据 情况 选 作 ， 如 系统 自动 分 班 
功能 、 班 级 管理 、 组 织 发 展 、 毕 业 生 管理 、 奖 学 金 /助学金 的 发 放 等 。 

3. 数据 操作 要 求 

要 求 可 以 对 数据 库 中 的 数据 进行 基本 的 操作 ， 具 体 包括 以 下 内 容 。 

(1) 插入 : 插入 新 的 数据 。 

(2) 删除 ， 删 除 已 有 的 数据 。 

(3) 修改 : 修改 已 有 数据 。 

(4) 查询 : 按照 一 定 的 条 件 ， 查 询 符合 条 件 的 记录 。 

(5) 统计 : 按 给 定 的 条 件 对 特定 的 信息 (如 成 绩 的 总 分 、 均 分 等 ) 进 行 统计 、 分 析 。 

(6) 打印 : 对 查询 、 统 计 的 结果 打印 输出 。 


4. 数据 库 要 求 
(D 在 数据 库 中 应 该 包含 必要 的 表 。 
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QQ) 要 求 必须 使 用 一 次 视图 。 
G) 游标 可 选用 。 
(4) 存储 过 程 可 选用 。 


三 、 课 程 设计 内 容 及 进度 安排 


1. 课程 设计 内 容 

数据 库 系统 原理 及 应 用 课程 设计 要 求学 生 综合 利用 本 课程 的 有 关 知 识 ， 在 教师 的 
指导 下 ， 利 用 特定 的 数据 库 设计 环境 ， 针 对 具体 的 问题 ， 完 成 从 系统 的 需求 分 析 、 数 
据 库 的 概念 设计 、 数 据 库 的 逻辑 设计 到 数据 库 实现 等 设计 过 程 ， 最 终 实现 一 个 较为 完 
整 的 反映 应 用 需求 的 数据 库 应 用 系统 。 因 此 ， 在 设计 中 ， 要 求学 生 应 该 全 面 考虑 各 个 
设计 环节 及 它们 之 间 的 相互 联系 。 

下 面 是 各 个 设计 阶段 的 具体 内 容 。 

(1) 系统 需求 分 析 

需求 分 析 是 数据 库 系统 设计 的 一 个 重要 的 环节 。 本 阶段 应 该 对 整个 应 用 情况 作 全 
面 的、 详细 的 调查 ， 确 定 特定 数据 库 应 用 环境 下 的 设计 目标 ， 收 集 该 应 用 环境 下 针对 
系统 设计 所 需要 的 基础 数据 及 对 这 些 数据 的 具体 存储 要 求 ， 从 而 确定 用 户 的 需求 。 用 
户 对 数据 库 的 需求 包括 以 下 内 容 。 

@ 处 理 需求 。 学 生 在 设计 中 应 根据 具体 的 课题 要 求 确定 系统 应 该 实现 的 功能 ， 

- 些 基 本 的 功能 通常 是 必须 具备 的 ， 如 用 户 的 管理 与 维护 、 基 本 数据 的 维护 、 灵 活 的 

信息 查询 等 。 

@ 信息 需求 。 即 在 数据 库 中 需要 存储 哪些 数据 。 学 生 应 该 根据 具体 的 课题 ， 认 
真 分 析 有 关 的 要 求 ， 确 定 设计 的 信息 需求 。 

@ 安全 性 和 完整 性 功能 。 在 实践 中 ， 这 是 一 个 需要 与 用 户 不 断交 流 才 能 逐步 确 
定 的 需求 。 本 课程 设计 要 求学 生 在 自己 的 设计 中 能 反映 出 基本 的 安全 性 和 完整 性 功能 。 

本 阶段 的 设计 结果 ( 即 系统 需求 分 析 ) 应 该 在 课程 设计 报告 中 进行 详细 描述 ， 画 出 
系统 的 数据 流 图 ， 写 出 较为 详细 的 数据 字典 ， 作 为 本 课程 设计 的 验收 依据 之 一 。 

(2) 数据 库 的 概念 设计 

数据 库 的 概念 设计 是 在 需求 分 析 的 基础 上 ， 利 用 与 用 户 双方 都 能 理解 的 形式 ， 设 
计 出 数据 库 的 概念 模型 。 本 课程 设计 要 求学 生 采 用 E-R 方法 进行 数据 库 的 概念 设计 。 

本 设计 阶段 可 分 为 如 下 几 点 。 

Q 数据 抽象 。 即 根据 需求 分 析 的 结果 ， 抽 取出 与 本 课程 设计 相关 的 特性 。 

@ 设计 局 部 概念 模式 。 运 用 E-R 方法 ， 设 计 出 系统 的 各 个 局 部 E-R 模型 。 

@ 设计 全 局 概念 模式 。 通 过 对 局 部 E-R 模型 的 操作 ， 解 决 各 个 E-R 模型 关于 对 
象 定义 不 一 致 问题 ， 以 及 对 各 个 E-R 模型 进行 合并 优化 等 ， 最 终 形成 数据 库 的 全 局 概 

本 阶段 的 设计 结果 (局 部 和 全 局 E-R 图 、 具 体 数 据 库 设计 工具 中 的 概念 结构 设计 图 ) 
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应 该 在 课程 设计 报告 中 进行 详细 描述 ， 应 该 能 够 反映 该 设计 的 正确 性 ， 作 为 本 课程 设 
计 的 验收 依据 之 一 。 

G) 数据 库 的 逻辑 设计 

数据 库 逻辑 设计 的 目的 是 将 概念 设计 阶段 设计 好 的 ER 图 转换 成 与 具体 计算 机 上 
的 DBMS 所 支持 的 数据 模型 (如 关系 模型 ) 相 符合 的 逻辑 结构 。 鉴 于 本 课程 设计 的 具体 
环境 要 求 ， 学 生 在 进行 数据 库 的 逻辑 结构 设计 时 ， 应 该 充分 考虑 特定 的 数据 库 环境 。 

要 求学 生 在 本 阶段 的 设计 中 分 以 下 两 步 进行 。 

@ 形成 初始 的 关系 模式 。 将 概念 设计 阶段 产生 的 全 局 概念 模式 (E-R 图 ) 转 换 成 初 
始 的 关系 模式 。 

@ 关系 模式 的 规范 化 处 理 。 为 了 减少 或 消除 关系 模式 中 存在 的 数据 元 余 和 操作 
异常 ， 根 据 设计 所 要 求 的 规范 级 别 ， 按 照 本 课程 所 学 知识 ， 逐 一 分 析 各 个 关系 模式 是 
否 满足 规定 的 范式 。 

在 课程 设计 报告 中 应 该 提供 本 设计 阶段 的 相关 内 容 ， 作 为 本 课程 设计 的 验收 依据 
之 一 。 

(4) 创建 数据 库 
在 某 一 数据 库 管 理 系统 环境 中 创建 数据 库 ， 根 据 需要 也 可 建立 相关 数据 视图 和 
存储 过 程 。 

在 课程 设计 报告 中 应 该 提供 相关 的 内 容 ， 包 括 数据 库 及 各 个 数据 库 对 象 的 定义 的 
SQL 语句 ， 作 为 本 课程 设计 的 验收 依据 之 一 。 

(5) 程序 设计 

运用 掌握 的 语言 ， 编 写 程序 ， 实 现 所 设计 的 模块 功能 。 首 先 学 会 设计 数据 库 应 用 
界面 ， 能 将 数据 库 与 应 用 界面 联系 起 来 ， 然 后 使 用 前 台 语言 对 相关 的 关系 数据 库 表 纺 
程 ， 完 成 相应 的 功能 。 

(6) 系统 调试 与 测试 

将 各 功能 模块 有 机 地 连接 起 来 ， 形 成 一 个 系统 的 数据 库 应 用 软件 。 然 后 进行 软 
件 功能 验证 ， 针 对 出 现 的 问题 ， 仔 细 分 析 ， 查 找 解决 问题 的 方法 并 进行 改正 ， 直 至 
整体 功能 全 部 实现 。 

2. 课程 设计 进度 

(1) 选 题 与 收集 资料 ， 选 择 课题 ， 在 小 组 内 进行 分 工 ， 进 行 系统 调查 ， 收 集资 料 。 

(2) 需求 分 析 : 根据 自己 的 选 题 ， 绘 制图 表 及 书写 相关 的 文字 说 明 。 

(G3) 概念 结构 设计 : 绘制 所 选 题目 详细 的 ER 图 。 

(4) 逻辑 结构 设计 将 ER 图 转换 成 等 价 的 关系 模式 ， 按 需求 对 关系 模式 进行 规 
范 化 ， 对 规范 化 后 的 模式 进行 评价 ， 调 整 模式 ， 使 其 满足 性 能 、 存 储 等 方面 要 求 ， 根 
据 局 部 应 用 需要 设计 外 模式 。 

(5) 物理 结构 设计 ， 选 定 实施 环境 、 存 取 方 法 等 。 

(@ 数据 实施 和 维护 ， 用 DBMS 建立 数据 库 结构 ， 加 载 数据 ， 实 现 各 种 查询 、 链 
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接应 用 程序 ， 设 计 库 中 触发 器 、 存 储 器 等 对 象 ， 并 能 对 数据 库 做 简单 的 维护 操作 。 
(7) 设计 数据 库 的 操作 界面 (可 选 )。 
(8) 课程 设计 小 结 : 总 结 课程 设计 的 过 程 、 体 会 及 建议 。 








、 课 程 设计 选 题 


1. 参考 选 题 范围 

(1) 通用 工资 管理 系统 

(2) 人 事 管理 系统 

(3) 仓库 管理 系统 

(4) 图 书馆 管理 信息 系统 
(5) 宾馆 客房 管理 信息 系统 
(6) 机 票 预订 系统 

















(14) 教学 管理 系统 
2. 参考 选 题 及 设计 要 求 


(1) 人 事 管理 系统 
系统 功能 的 基本 要 求 : 
员工 各 种 信息 的 输入 ， 包 括 员工 的 基本 信息 、 学 历 信息 、 婚 姻 状 况 信息 、 职 





@ 员工 各 种 信息 的 修改 。 

@ 对 于 转 出 、 辞 职 、 辞 退 、 退 休 员 工 信 息 的 删除 。 

@ 按照 一 定 的 条 件 ， 查 询 、 统 计 符合 条 件 的 员工 信息 ; 能 够 查询 每 个 员工 详细 
信息 ， 如 按 婚姻 状况 查询 、 按 学 历 查 询 、 按 工作 岗位 查询 等 ， 还 能 够 按 学 历 、 婚 姻 状 
况 、 岗 位 、 参 加 工作 时 间 等 统计 各 自 的 员工 信息 。 

@@ 对 查询 、 统 计 的 结果 打印 输出 。 

(2) 机 票 预订 系统 

系统 功能 的 基本 要 求 : 

Q@ 每 个 航班 信息 的 输入 。 

@ 每 个 航班 的 座位 信息 的 输入 。 











*“114。 数据 库 系统 原理 及 应 用 课程 设计 与 实验 指导 


@ 当 旅客 进行 机 票 预订 时 ， 输 入 旅客 基本 信息 ， 系 统 为 旅客 安排 航班 ， 打 印 取 
票 通知 和 账单 。 

@ 旅客 在 飞机 起 飞 前 一 天 赁 取 票 通知 交 款 取 票 。 

@ 旅客 能 够 退 订 机 票 。 

@ 能 够 查询 每 个 航班 的 预订 情况 ， 计 算 航班 的 满座 率 。 

(3) 学 生 学 籍 管理 信息 系统 

学 生 学 籍 管理 工作 包括 学 生 档案 、 学 籍 、 成 绩 、 升 学 等 内 容 的 管理 。 

本 系统 需要 完成 的 具体 任务 如 下 : 

@ 学 生 档案 的 管理 ， 即 录入 、 修 改 、 查 询 、 输 出 学 生 档案 信息 ， 这 些 信 息 包括 
学 生 基本 情况 、 学 生 简历 情况 、 学 生 奖 励 情况 、 学 生 处 分 情况 、 学 生 家 庭 信息 、 学 生 
体检 情况 。 

@ 学 生 学 籍 管理 ， 即 录入 、 修 改 、 查 询 、 输 出 学 生 学 籍 信息 ， 这 些 信 息 包括 学 
生 奖 贷 学 金 情 况 、 学 生 注 册 、 学 生 异 动情 况 、 学 生 军 训 情 况 、 学 生 毕 业 情 况 。 

@ 学 生成 绩 管理 ， 即 录入 、 修 改 、 查 询 、 输 出 学 生 入 校 成 绩 ， 各 学 期 、 各 门 课 
旺 的 成 绩 信 息 ， 并 支持 按 年 级 、 班 级 等 条 件 的 统计 、 查 询 、 报 表 输 出 。 

@ 系统 管理 模块 包括 用 户 密码 修改 、 用 户 权限 设置 、 用 户 添加 、 删 除 等 。 

@ 系统 维护 模块 包括 系统 初始 化 、 数 据 库 备 份 、 数 据 库 还 原 等 。 

@ 系统 帮助 模块 包括 系统 安装 、 介 绍 、 使 用 等 。 





、 建 议 教 材 与 参考 书 


教材 : 

[1] 王 珊 ， 萨 师 迷 . 数据 库 系 统 概论 (第 5 版 ) 北京 : 高 等 教育 出 版 社 ，2014. 
主要 参考 书 : 

[1] 施 伯乐 ， 等 . 数据 库 系 统 教程 . 北京 高 等 教育 出 版 社 ，2003. 

[2] 丁 宝 康 ， 等 . 数据 库 原理 . 北京 : 经 济 科学 出 版 社 ，2000. 

[3] 崔 赂 . 数据 库 系统 及 应 用 (第 二 版 ). 北京 ， 高 等 教育 出 版 社 ，2003. 

[4] 李 卓 玲 . 数据 库 原理 与 应 用 . 北京 : 电子 工业 出 版 社 ，2000. 


六 、 课 程 设计 成 果 (论文 ) 要 求 


课程 设计 报告 要 求 : 

(1) 课程 设计 报告 不 少 于 3000 字 ， 以 Word 文档 形式 提交 ， 需 打印 。 

(2) 课程 设计 报告 封面 应 有 题目 、 班 级 、 姓 名 、 学 号 、 完 成 日 期 、 指 导 教 师 等 的 
说 明 。 

(3) 课程 设计 报告 正文 一 般 要 求 包 含 以 下 几 个 方面 的 内 容 。 

@ 课程 设计 的 说 明 : 包括 程序 的 开发 环境 、 运 行 环境 、 开 发 工具 及 版 本 、 安 装 
配置 的 方法 、 简 洁 的 操作 指南 (如 果 需 要 )。 

@ 系统 分 析 报 告 : 包括 系统 的 需求 分 析 、 系 统 的 功能 模块 设计 、 数 据 库 的 数据 
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字典 、 数 据 库 的 概念 结构 (E-R 图 )、 罗 辑 模型 (用 到 的 表 、 视 图 、 存 储 过 程 等 数据 库 
对 象 ) 的 结构 和 定义 ( 表 和 视图 的 结构 用 表格 的 形式 给 出 , 包括 列 名 、 数 据 类 型 、 长 度 、 
是 否 为 主键 、 说 明 等 )。 

@ 程序 的 详细 设计 : 包括 功能 模块 之 间 的 关系 、 模 块 的 功能 、 主 要 功能 实现 的 方 


法 等 











@ 程序 的 实现 : 包括 2~3 个 程序 运行 的 主要 窗口 的 截图 、 具 有 代表 性 的 功能 包 
实现 方法 的 说 明和 主要 代码 (要 有 较 完整 的 注释 )。 要 求 能 够 体现 程序 设计 中 的 重点 和 
难点 及 设计 者 的 能 力 和 主要 工作 。 

@ 课程 设计 小 结 : 包括 设计 者 的 收获 、 系 统 的 优点 和 不 足 、 有 待 改 进 的 地 方 、 
对 这 次 课程 设计 的 感想 和 体会 等 内 容 。 

@ 附录 或 参考 资料 。 

(4) 要 求 提交 的 电子 文档 如 下 。 

@ 设计 报告 的 Word 文档 。 

@ 源 程序 和 脚本 、 编 译 后 的 程序 ， 以 及 程序 中 用 到 的 特殊 的 插件 和 动态 库 等 。 

@ 数据 库 设计 的 模型 (如 果 有 ， 如 PowerDesigner 的 CDM、PDM 文件 ， 或 使 用 
其 他 数据 库 辅助 设计 工具 设计 的 包含 概念 模型 、 逻 辑 模型 的 文件 )。 

@ 生成 表 、 视 图 、 存 储 过 程 等 数据 库 对 象 的 SQL 脚本 (此 内 容 可 由 工具 生成 ， 保 
存 为 文本 文件 的 形式 )。 
@ SQL Server 2012 导出 的 数据 文件 (如 果 需 要 )。 





@ 简洁 的 使 用 手册 (如 果 需 要 ): 除 简洁 的 操作 指南 外 ， 还 应 说 明 系 统 对 软件 环境 
的 要 求 、 安 装 和 配置 的 方法 、 系 统 配置 文件 (*.ini)、 初 始 登录 账号 和 密码 等 内 容 。 
@ 课程 设计 涉及 的 ， 设 计 者 认为 有 必要 提交 的 其 他 文档 。 


七 、 课 程 考核 方式 与 成 绩 评定 办 法 


1. 课程 考核 方式 

本 课程 成 绩 评 定 实行 百分制 。 指 导 教 师 根据 学 生 完成 任务 的 情况 ， 结 合 课程 设计 
中 工作 量 、 操 作 演 示 、 设 计 讲 解 、 回 答 问 题 、 设 计 能 力 、 设 计 报告 等 方面 综合 打分 。 

(1) 工作 量 : 考查 学 生 完成 设计 的 工作 量 大 小 ， 从 难度 、 完 成 情况 等 方面 考查 。 

(2) 操作 演示 : 主要 考查 学 生 的 操作 能 力 、 熟 练 程度 等 。 

(3) 设计 讲解 : 考查 学 生 对 整体 设计 的 认识 和 把 握 。 

(4) 回答 问题 : 是 否 能 够 正确 回答 指导 教师 所 提 的 问题 。 

(5) 设计 能 力 : 是 否 具有 独立 分 析 、 解 决 问题 的 能 力 ， 主 要 考查 在 规定 时 间 内 完 
成 任务 情况 , 或 是 否 满足 实际 要 求 ; 包含 数据 库 的 设计 和 应 用 程序 的 设计 (用 户 界面 、 
实现 方法 等 )。 

(6) 设计 报告 : 是 否认 真 撰写 设计 报告 ， 内 容 是 否 客观 、 正 确 、 完 整 。 














2. 成 绩 评定 办 法 

(D 90 一 100: 完成 任务 书 中 要 求 的 所 有 内 容 ， 系 统 运行 正确 ， 功 能 完善 ， 文 档 详 
细 ， 数 据 库 设 计 合理 ， 人 机 接口 界面 友好 ， 工 作 量 充分 。 

(2) 80 一 89: 完成 任务 书 中 要 求 的 大 部 分 内 容 ， 系 统 运行 正确 ， 功 能 较为 完善 ， 
文档 较 详细 ， 数 据 库 设计 较 合 理 ， 人 机 接口 界面 较 好 ， 工 作 量 较 大 。 

(3) 70 一 79: 完成 任务 书 中 要 求 的 大 部 分 内 容 ， 系 统 运 行 正确 ， 功 能 基本 完善 ， 
文档 较 详细 ， 数 据 库 设计 基本 合理 ， 有 基本 的 人 机 接口 界面 ， 工 作 量 适 中 。 

(4) 60 一 69: 完成 任务 书 中 要 求 的 基本 内 容 ， 系 统 运行 基本 正确 ， 完 成 基本 数据 
增 、 删 、 改 、 查 功能 ， 文 档 有 系统 主要 功能 的 介绍 ， 工 作 量 偏 少 。 

(5) 分 数 小 于 60( 不 及 格 ): 未 按时 完成 任务 书 中 要 求 的 设计 内 容 ， 或 未 按时 呈 交 
设计 文档 与 光盘 者 。 














制定 /修订 人 : Xxx 

审定 人 : XXX 

批准 人 : Xxx 

制定 /修订 时 间 : XXX 年 XXX 月 
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“数据 库 系统 原理 及 应 用 ”课程 设计 实施 方案 


一 、 课 程 设计 的 性 质 与 目的 


数据 库 系统 原理 及 应 用 课程 设计 是 数据 库 系 统 原理 及 程序 设计 等 课程 的 后 续 实 践 性 
课程 ， 是 一 门 独立 开设 的 实践 性 课程 ， 也 是 毕业 设计 等 后 续 课程 的 基础 。 数 据 库 系 统 原理 
及 应 用 课程 设计 对 于 巩固 数据 库 知 识 ， 加 强 学 生 的 实际 动手 能 力 和 提高 学 生 综合 素质 十 
分 必要 。 

数据 库 系统 原理 及 应 用 课程 设计 的 主要 目标 如 下 。 

(1) 加 深 对 数据 库 系统 原理 及 程序 设计 的 理论 知识 的 理解 和 应 用 。 

(2) 通过 设计 实际 的 数据 库 系 统 课题 ， 进 一 步 熟 悉数 据 库 管 理 系统 的 操作 技术 ， 提 高 
动手 能 力 、 分 析 问 题 和 解决 问题 的 能 力 。 

(3) 学 习 基本 的 数据 库 编程 方法 。 


二 、 课 程 设计 的 时 间 分 配 


表 8-1 课程 设计 的 时 间 分 配 
设计 内 容 时 间 (天 ) 要 求 
选择 课题 ， 收 集资 料 ， 进 行 课程 在 小 组 内 进行 分 工 ， 并 进行 系统 调查 ， 收 集 
设计 的 准备 工作 > 相关 资料 ， 进 一 步 熟 悉 开发 工具 
a 进行 系统 需求 分 析 和 系统 设计 ， 得 出 系统 的 
人 数据 流 图 、 数 据 字典 和 信息 模型 
按 数据 库 设计 方法 和 规范 化 理论 ， 得 出 符合 
3NF 的 数据 模型 
数据 库 定义 和 数据 安全 性 与 完整 定义 SQL Server 的 基本 表 、 视图、 图 表 和 安 
性 定义 全 性 、 完 整 性 要 求 
设计 并 编写 输入 /输出 、 查询 /统计 、 数 据 维 护 
等 功能 模块 的 应 用 程序 
对 系统 的 各 个 功能 模块 进行 集成 、 总 调试 和 
优化 工作 ， 优 化 用 户 界面， 撰写 设计 报告 
验收 和 答 状 上 机 演示 系统 并 进行 答辩 








数据 库 设计 





应 用 程序 设计 和 程序 调试 





系统 集成 和 优化 及 撰写 设计 报告 














三 、 设 计 选 题 与 设计 内 容 


1. 选 题 要 求 

(1) 分 组 选 题 ， 每 组 3~4 人 ， 每 组 选取 一 题 。 

(2) 每 班 分 组 不 能 超过 ** 组 ， 每 题 必须 被 选取 ， 但 最 多 只 能 被 ** 组 参 选 。 

(3) 选 题 确定 后 ， 由 组 内 成 员 指 定 小 组 长 ， 并 进行 分 工 ， 组 织 大 家 共同 完成 课程 设计 。 


2. 设计 内 容 


根据 所 学 的 数据 库 系统 与 程序 设计 的 知识 ， 对 所 选 的 题目 进行 系统 需求 分 析 、 系 统 设 
计 、 数 据 库 设 计 、 编 码 、 测 试 等 ， 完 成 题目 要 求 的 功能 ， 从 而 达到 掌握 开发 一 个 小 型 数据 
库 系 统 的 目的 ， 具 体内 容 如 下 。 

(1) 对 各 个 系统 进行 系统 功能 需求 分 析 和 数据 分 析 。 

(2) 在 数据 库 设 计 分 析 阶 段 ， 进 行 详细 的 数据 库 需 求 分 析 、 概 念 数据 库 的 设计 ， 画 出 
数据 库 的 E-R 图 (包括 局 部 和 整体 E-R 图 )。 

(3) 设计 出 详细 的 逻辑 数据 库 结构 ， 将 各 个 实体 和 联系 转化 为 相应 的 二 维 表 ( 即 关 系 模 
式 )， 指 定 各 个 关系 的 主 码 和 外 码 ， 并 对 各 个 关系 的 约束 加 以 限定 。 

(4) 完成 数据 库 定义 工作 ， 实 现 系 统 数据 的 数据 录入 和 数据 处 理 。 

(5) 通过 对 象 资源 管理 器 或 查询 分 析 窗 口 实现 各 个 二 维 关系 (建议 最 好 用 SQL 代码 实 
现 )， 要 求 建立 相关 的 索引 。 

(6) 根据 系统 功能 需求 设计 相应 的 查询 视图 。 

(7) 根据 系统 功能 需求 建立 存储 过 程 。 

(8) 根据 功能 需求 建立 相应 的 触发 器 ， 以 保证 数据 的 一 致 性 。 

(9) 实现 对 数据 的 各 种 操作 ， 如 创建 视图 、 增 删改 查 操作 、 实 验 验 证 功能 ， 其 中 验证 
部 分 由 题目 、 结 果 和 相应 的 代码 组 成 。 

(10) 通过 建立 用 户 和 权限 分 配 实现 数据 库 一 定 的 安全 性 ， 考 虑 数据 库 的 备份 与 恢复 
(此 内 容 选 作 )。 


四 、 课 程 设 计 题 目 

















(一 ) 学 生 宿 舍 管理 信息 系统 


1. 背景 资料 

(1) 入 校 时 ， 每 位 学 生 都 有 唯一 的 学 号 ， 并 被 分 配 到 指定 的 宿舍 楼 和 指定 的 宿舍 ， 也 
会 有 一 个 宿舍 号 ， 其 入 校 时 间 就 是 他 的 入 住 时 间 。 

(2) 每 间 宿舍 都 有 唯一 的 宿舍 号 ， 入 校 时 ， 宿 舍 会 安装 公用 电话 机 ， 相 应 地 就 有 宿舍 
电话 号 码 。 

(3) 每 个 宿舍 的 财产 属于 学 校 ， 如 电灯 、 床 铺 、 柜 子 、 桌 椅 等 ， 为 了 对 不 同 的 财产 进 
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行 区 分 ， 可 以 为 每 种 财产 分 配 不 同 的 财产 号 ， 这 样 有 利于 财产 的 报修 和 管理 。 

(4) 宿舍 楼 中 经 常 出 现 财产 的 损坏 ， 比 如 ， 灯 泡 坏 了 ， 而 所 的 马桶 出 故障 了 等 ， 这 时 ， 
学 生 们 需要 将 财产 损坏 情况 报告 给 宿舍 楼 管理 员 ， 以 便 学 校 派 人 进行 维修 。 

(5) 宿舍 楼 在 指定 的 时 间 关 门 (如 晚上 12 点 )， 若 有 学 生 晚 于 关门 时 间 回 宿舍 ， 需 通知 
宿舍 楼 管理 员 ， 同 时 应 登记 晚 归 学 生 姓名 、 宿 舍 号 、 时 间 和 晚 归 原因 ， 以 利于 学 校 的 管理 
和 查证 。 

(9) 为 加 强 学 校对 学 生 假 期 安全 的 管理 ， 离 校 的 学 生 应 登记 离 校 时 间 ， 待 返 校 后 记录 
返 校 时 间 ， 以 便 学 校 查证 和 管理 。 

2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 宿舍 的 基本 信息 管理 。 

(2) 学 生 的 基本 信息 管理 。 

(3) 宿舍 财产 的 基本 信息 管理 。 
(4) 报修 的 基本 信息 管理 。 
(5) 夜 归 的 基本 信息 管理 。 
(6) 离 校 的 基本 信息 管理 。 

(7) 查询 及 统计 报表 。 











(二 ) 图 书 管理 系统 


1. 背景 资料 
(1) 图 书 室 有 各 种 图 书 ， 共 一 万 多 册 。 
(2) 每 种 图 书 都 有 书 名 、 书 号 ISBN)、 一 名 或 多 名 作者 ( 译 者 )、 出 版 社 、 定 价 和 内 容 





(3) 借 书 证 记录 有 借阅 者 的 姓名 、 所 在 单位 、 职 业 等 。 
(4) 凭借 书证 借 书 ， 每 次 最 多 能 借 8 本 书 。 借 书 期 限 最 长 为 30 天 。 
2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 图 书 基本 情况 的 录入 、 修 改 、 删 除 等 基本 操作 。 
(2) 实现 借 书 功 能 。 

(3) 实现 还 书 功 能 。 

(4) 实现 对 所 有 购 进 图 书 的 分 类 查询 和 分 类 统计 。 
(5) 能 够 按 书 名 、 作 者 等 分 类 查询 现 有 图 书 的 数量 。 
(6) 对 超期 的 情况 能 自动 给 出 提示 信息 。 























(三 ) 库存 物资 管理 系统 


1. 背景 资料 


(D 有 一 个 存放 商品 的 仓库 ， 每 天 都 有 商品 出 库 和 入 库 。 

(2) 每 种 商品 都 有 名 称 、 生 产 三 家、 型 号 、 规 格 等 。 

(3) 出 入 库 时 必须 填写 出 入 库 单 据 ， 单 据 包 括 商品 名 称 、 生 产 厂 家 、 型 号 、 规 格 、 数 
期 、 时间、 入 库 单位 (或 出 库 单位 ) 名 称 、 送 货 (或 提货 ) 人 姓名 。 


2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 设计 出 入 库 单据 的 管理 (录入 、 修 改 、 删 除 )。 

(2) 实现 按 商 品名 称 、 出 入 库 日 期 的 查询 。 

(3) 实现 分 别 按 日 、 月 和 年 对 出 入 库 商 品 数 量 的 统计 。 
(4) 输出 相应 的 数据 报表 。 




















(四 ) 工资 管理 系统 


1. 背景 资料 

(1) 某 单位 现 有 1000 名 员工 ， 其 中 有 管理 人 员 、 财 务 人 员 、 技 术 人 员 和 销售 人 员 。 

(2) 该 单位 下 设 4 个 科室 ， 即 经 理 室 、 财 务 科 、 技 术科 和 销售 科 。 

(3) 工资 由 基本 工资 、 福 利 补贴 和 奖励 工资 构成 , 失业 保险 和 住房 公积金 在 工资 中 扣除 。 

(4) 每 个 员工 的 基本 资料 有 姓名 、 性 别 、 年 龄 、 单 位 和 职业 (如 经 理 、 工程 师 、 销售 员 等 )。 

(5) 每 月 个 人 的 最 高 工资 不 超过 3000 元 。 工 资 按 月 发 放 ， 实 际 发 放 的 工资 金额 为 工资 
减 去 扣除 。 


2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 实现 按照 科室 录入 、 修 改 个 人 的 基本 资料 、 工 资 和 扣除 金额 的 数据 。 
(2) 计算 个 人 的 实际 发 放 工 资 。 

(3) 按 科 室 、 职 业 分 类 统计 人 数 和 工资 金额 。 

(4) 实现 分 类 查询 。 

(5) 能 够 删除 辞职 人 员 的 数据 。 

(6) 输出 相应 的 数据 报表 。 


(五 ) 宾馆 管理 系统 





1. 背景 资料 


(1) 宾馆 有 一 名 总 经 理 、 多 名 会 计 和 多 名 前 台 。 总 经 理 负责 宾馆 的 日 常 运营 
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责 对 宾馆 收入 支出 的 统计 管理 。 前 台数 据 包括 职工 号 等 ， 职 工 号 在 宾馆 内 唯一 。 

(2) 宾馆 有 各 种 标准 的 房间 。 房 间 数据 包括 房间 号 、 房 间 级 别 、 房 间 价位 及 房间 的 状 
态 (是 否 已 经 有 客人 )。 房 间 号 唯一 表示 一 个 房间 ， 房 间 级 别 决定 房间 价位 。 房 间 有 多 种 级 
别 ， 分 别 为 单 人 间 、 标 准 间 、 豪 华 间 、 商 务 间 、 行 政 间 。 房 间 状态 表示 此 房间 是 否 可 以 预 
订 、 入 住 或 者 转 房 。 

2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 房间 管理 。 

(2) 客人 预订 、 退 订 客 房管 理 。 
(3) 客人 入 住 、 店 内 消费 管理 。 
(4) 客人 换 房管 理 。 

(5) 结算 管理 。 

(6) 贵宾 卡 发 放 管理 。 

(7) 实现 分 类 查询 。 

(8) 输出 相应 的 数据 报表 。 


(六 ) 户籍 管理 系统 


1. 背景 资料 


可 满足 基层 单位 (派出 所 、 企 事业 单位 保卫 部 门 、 街 道 、 社 区 、 住 宅 小 区 等 ) 需 要 ， 管 
理 连 区 内 人 员 户 籍 的 迁 入 、 迁 出 、 变 更 登记 等 。 


2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 辖区 单位 管理 。 

(2) 户籍 基本 信息 管理 。 
(3) 户籍 迁 入 、 迁 出 管理 。 
(4) 户籍 注销 管理 。 

(5) 查询 。 








区 业主 信息 、 物 业 管理 费用 信息 、 水 
信息 、 有 线 电视 费用 信息 、 供 暖 费用 信息 、 业 主 房 款 缴纳 信息 ， 并 且 可 以 打 
印 输出 上 述 信息 报表 (月 报表 、 季 报表 、 年 报表 ) 的 管理 系统 。 
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2. 基本 要 求 


能 实现 以 下 主要 功能 : 

(1) 业主 的 基本 信息 管理 。 

(2) 记录 月 水 电 煤气 抄 表 数 据 ， 并 打印 业主 交 费 通知 单 。 
(3) 记录 业主 交 费 情况 并 打印 交 费 单 。 

(4) 统计 业主 相关 信息 的 月 、 季 和 年 报表 。 

(5) 异常 处 理 。 


( 八 ) 实验 室 设备 管理 系统 








zz、 办公 室 设备 的 集中 和 自动 化 管理 ， 需 要 一 套 网 络 版 的 设备 运营 和 管 


能 实现 以 下 主要 功能 : 
(1) 基本 设备 管理 。 
(2) 用 户 管理 。 

(3) 故障 设备 人 


(4) 维修 过 程 管理 。 
(5) 打印 各 种 报表 。 


( 九 ) 汽车 租赁 管理 信息 系统 

1. 背景 资料 

汽车 租赁 管理 信息 系统 可 以 帮助 企业 处 理 日 常 工作 业务 ， 规 范 管理 各 项 工作 和 操作 流 
程 ， 提 供 预 订 汽车 ， 对 合同 的 添加 、 删 除 、 修 改 ， 对 客户 和 员工 的 信息 管理 等 功能 ， 高 效 
地 完成 各 种 汽车 租赁 经 营 中 的 信息 统计 、 计 算 和 汇总 工作 。 

2. 基本 要 求 

能 实现 以 下 主要 功能 ; 

(D 租赁 车 辆 信息 的 管理 。 

C) 租赁 客户 信息 的 管理 。 

G) 合同 信息 的 管理 。 

(9 日 常 租赁 业务 的 管理 。 

(5) 打印 各 种 报表 。 
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系统 ， 帮 助 企业 处 理 日 常 工作 业务 ， 规 范 管理 各 项 工作 和 操作 流程 。 

2. 基本 要 求 

能 实现 以 下 主要 功能 : 

(1) 桌 台 管理 。 

(2) 就 餐 管 理 ， 包 括 开 台 、 点 餐 、 

(3) 菜单 管理 。 

(4) 用 户 管理 。 

(5) 营业 额 管理 。 

(6) 系统 维护 。 

(以 上 各 题目 可 根据 学 生 的 情况 进行 适当 的 调整 和 改变 ) 
五 、 课 程 设 计 上 交 资 料及 装订 要 求 

课程 设计 结束 后 ， 学 生 应 提交 的 文档 包括 纸 质 文档 和 电子 文档 。 

1. 纸 质 文档 

(1) 《课程 设计 任务 书 》1 份 。 

(2) 《课程 设计 报告 》1 份 。 

装订 要 求 : 

@ 《课程 设计 任务 书 》《 课 程 设计 报告 》 等 有 关 资 料 的 版 面 格式 须 符合 第 6 章 “X x 
X 大 学 课程 设计 工作 规范 ”的 要 求 ， 并 用 A4 纸 打印 。 

@ 《课程 设计 报告 》 需 按 以 下 顺序 统一 装订 : 封面、 中 文摘 要 、 英 文摘 要 、 目 录 、 
正文 、 参 考 文献 、 附 录 、 按 规定 要 求 折 秋 的 工程 图 纸 。 

图 装订 好 的 《课程 设计 报告 》 和 《课程 设计 任务 书 》 需 装 入 “课程 设计 资料 袋 ”后 
上 交 。 课 程 设计 资料 袋 封面 具体 见 本 章 “ 课 程 设计 资料 袋 封面 ”。 

2. 电子 文档 

(1) 《课程 设计 任务 书 》。 

(2) 《课程 设计 报告 》。 

(3) 设计 好 的 数据 库 文件 。 

(4) 课程 设计 源 代码 。 

上 交 要 求 : 将 这 些 电子 文档 形成 一 个 压缩 文件 ， 文 件 名 为 : 学 号 -姓名 -课程 设计 名 ， 
发 送 至 指导 教师 的 邮箱 。 
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六 、 课 程 设计 评审 标准 
课程 设计 评审 标准 如 表 8-2 所 示 。 





评审 项 目 


表 8-2 课程 设计 评审 标准 
指标 





工作 量 及 工作 态度 


调查 论证 


按期 完成 规定 任务 ， 难 易 程 度 和 工作 量 符合 教学 要 求 ， 
体现 本 专业 基本 训练 的 内 容 ， 工 作 认 真 ， 遵 守 纪 律 ; 
作风 严谨 务实 

能 独立 查阅 文献 和 调研 ， 能 正确 翻译 外 文 资料 ， 有 综 
合 、 收 集 和 正确 利用 各 种 信息 的 能 力 





内 容 设计 、 实 验方 案 


与 实验 技能 


内 容 设计 、 实 验方 案 科学 合理 ， 方 案 具 体 可 行 ， 能 
立 操作 实验 ， 数 据 采 集 、 计 算 、 处 理 正 确 ， 结 构 设计 
: 确 、 程 序 运行 可 靠 





央 


分 析 与 解决 问题 的 
地 力 


设计 报告 质量 


设计 创新 


综述 材料 与 调查 论证 


设计 、 推 导 、 计 算 与 


验证 


设计 质量 


设计 创新 


识 和 技能 去 发 现 与 解决 实际 问题 ， 能 对 
题目 进行 理论 分 析 ， 并 得 出 有 价值 的 结论 
立论 正确 ， 论 据 充分 ， 结 构 严 谨 合 理 ， 实 验 正确 ， 分 
析 、 处 理 问题 科学 ;结构 格式 符合 课程 设计 规范 ; 文 
理 通 顺 ， 技 术 用 词 准确 、 规 范 ， 图 表 完 备 、 绘 图 正确 
具有 创新 意识 ， 对 前 人 工作 有 改进 、 突 破 ， 或 有 独特 
见解 ， 有 一 定 应 用 价值 
选 题 达 到 培养 目标 的 要 求 ， 难 易 程 度 、 工 作 量 大 小 合适 
根据 题目 任务 ， 能 独立 查阅 文献 资料 和 从 事 有 关 调 研 ; 
归纳 、 利 用 各 种 信息 的 能 力 ， 翻 译 外 文 资料 水 


方案 设计 合理 ， 具 有 可 操作 性 ;推导 正确 ， 计 算 准确 ， 
结构 合 [ 艺 可 行 ， 图样 绘制 与 技术 要 求 符合 国家 
标准 及 要 求 

论点 明确 ， 论 据 充 分 ， 结 论 正确 ， 条 理 清 晰 ， 文 理 通 
顺 ， 用 语 符合 技术 规范 ， 图 表 清晰 ， 书 写 格式 规范 
对 前 人 工作 有 改进 、 突 破 ， 或 有 独特 见解 有 一 定 应 
用 价值 








思路 清晰 ;语言 表达 准确 ， 概 念 清晰 ， 论 点 正确 ; 实 
验方 法 科学 ， 分 析 归 纳 合理 ， 结 构 严 说， 设计 有 应 用 
价值 











七 、 注 意 事项 


设计 创新 


准备 充分 ， 具 有 必要 的 影像 资料 ， 报 告 在 规定 的 时 间 
内 完成 

回答 问题 有 理论 依据 ， 基 本 概念 清晰 ， 主 要 问题 回答 
简明 准确 

对 前 人 工作 有 改进 、 突 破 ， 或 有 独特 见解 





1. 学 生 在 教师 的 指导 下 ， 应 积极 、 主 动 地 完成 课程 设计 所 规定 的 全 部 任务 。 
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2. 应 严格 按照 进度 进行 课程 设计 ， 不 得 无 故 拖延 。 

3. 小 组 成 员 之 间 ， 分 工 明确 ， 但 要 密切 合作 ， 培 养 良好 的 互相 帮助 和 团队 协作 精神 。 

4. 要 遵守 规定 的 作息 时 间 , 严格 遵守 纪律 , 原则 上 不 得 请 假 , 因 特 殊 原 因 必须 请 假 者 ， 
一 律 需 办 理 请 假手 续 。 

5. 按 规定 时 间 完 成 个 人 需要 撰写 的 课程 设计 报告 。 抄 袭 他 人 报告 内 容 (内 容 完全 相同 
的 两 份 以 上 设计 报告 作为 抄袭 处 理 )、 不 按 要 求 或 未 完成 全 部 内 容 、 无 故 旷课 两 次 及 以 上 、 
缺勤 时 间 达 三 分 之 一 及 以 上 者 ， 课 程 设 计 成 绩 定 为 不 及 格 。 
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附件 “课程 设计 资料 袋 封 面 





x XX 大 学 


X X X (课程 名 ) 
课程 设计 


题 目 
学 院 ( 系 ) 
专业 
班 级 
姓 名 
指导 教师 

















第 9 章 ”课程 设计 实例 


9.1 课程 设计 任务 书 


“数据 库 系统 原理 及 应 用 ”课程 设计 任务 书 


学 生 姓名 : 黄 Xx， 蓝 Xx， 林 xx,， 杨 xx 
专业 班级 : _15 计算 机 科学 与 技术 1 班 指导 教师 ，_ 胡 xx 


一 、 题 目 

小 型 书店 进 销 存 系统 

二 、 目 的 与 要 求 

本 课程 设计 的 目的 : 

1. 加 深 对 数据 库 系 统 基本 理论 和 基本 知识 的 理解 。 

2. 熟练 掌握 一 种 具体 的 数据 库 管 理 系统 的 使 用 方法 。 

3. 掌握 数据 库 应 用 系统 设计 的 全 过 程 ， 提 高 运用 数据 库 系 统 解决 实际 问题 的 能 力 。 

本 课程 设计 的 要 求 : 

1. 课程 设计 由 小 组 成 员 合作 完成 。 

2. 课程 设计 报告 不 少 于 3000 字 ， 报告 的 版 面 格 式 符合 “课程 设计 撰写 规范 ”， 提 交 报 
告 的 Word 文档 和 打印 稿 。 

3. 课程 设计 报告 封面 应 有 题目 、 班 级 、 姓 名 、 学 号 、 完 成 日 期 、 指 导 教师 等 项 目的 
说 明 。 

4. 课程 设计 报告 正文 一 般 要 求 包含 以 下 几 个 方面 的 内 容 。 

(1) 需求 分 析 。 

(2) 数据 库 的 概念 结构 设计 。 

(3) 数据 库 的 逻辑 结构 设计 。 

(4) 数据 库 的 物理 结构 设计 。 
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(5) 数据 库 的 完整 性 约束 和 安全 性 设计 。 

(6) 数据 的 查询 和 功能 验证 。 

(7) 课程 设计 小 结 。 

(8) 附录 或 参考 资料 。 

三 、 主 要 任务 

1. 对 系统 进行 功能 需求 分 析 和 数据 分 析 。 

2. 进行 数据 库 的 概念 结构 设计 ， 画 出 数据 库 的 E-R 图 (局 部 和 整体 E-R 图 )。 

3. 进行 数据 库 的 逻辑 结构 设计 , 将 各 实体 和 联系 转化 为 对 应 的 关系 模式 ， 并 进行 关系 
模式 优化 。 

4. 进行 数据 库 定义 数据库 、 基 本 表 、 索 引 、 数 据 库 完 整 性 )， 实 现 系统 数据 的 操作 。 

5. 根据 系统 功能 需求 ， 设 计 相 应 的 查询 视图 、 存 储 过 程 和 触发 器 。 

6. 数据 操作 验证 ， 设 计 查 询 语句 ， 并 在 查询 窗口 中 对 功能 需求 的 实现 进行 验证 。 

7. 通过 建立 用 户 和 权限 分 配 ， 实 现 数据 库 的 安全 性 ， 考 虑 数据 库 的 备份 与 恢复 。 


、 进 度 安排 








设计 内 容 时 间 ( 天 ) 设计 要 求 
过 局 司 收 于 医科 完成 分 组 并 进行 组 内 分 工 ， 进 行 系统 调查 ， 收 集资 料 ， 进 一 
I 步 熟 悉 开 发 环境 和 工具 


ee 界定 系统 范围 ， 描 述 系统 需求 (包含 数据 需求 和 功能 需求 )， 
需求 分 析 5 画 出 详细 的 数据 流 图 ， 写 出 数据 字典 

念 结构 设计 设计 系统 局 部 E-R 图 和 全 局 E-R 图 , 并 进行 冲突 和 宛 余 处 理 
迎 辑 结构 设计 完成 ER 模型 向 关系 模型 的 转换 , 以 及 对 关系 模型 进行 优化 
定义 数据 库 、 基 本 表 、 索 引 等 数据 对 象 和 数据 库 的 完整 性 ， 
并 在 SQL Server 上 进行 实现 
根据 系统 功能 需求 ， 设 计 相应 的 查询 视图 、 存 储 过 程 和 估 
用 SQL 语言 实现 对 数据 的 各 种 操作 ， 并 对 系统 的 功能 需求 
数据 操作 验证 ee 

进行 验证 

撰写 设计 报告 对 设计 的 数据 库 进行 联 调和 优化 ， 完 成 课程 设计 报告 的 撰写 
验收 和 答 状 上 机 演示 系统 ， 并 进行 答辩 


数据 库 定义 





数据 库 实 施 




















五 、 任 务 分 配 


学 生 姓名 主要 完成 的 任务 
黄 XX( 组 长 ) 需求 分 析 、 风 辑 结构 设计 、 数 据 库 定义 、 撰 写 设计 报告 、 
蓝 XX 需求 分 析 、 概 念 结构 设计 、 数 据 库 实 施 、 撰 写 设计 报告 
林 XX 需求 分 析 、 概 念 结构 设计 、 数 据 操作 验证 、 撰 写 设计 报告 
杨 X X 需求 分 析 、 数 据 库 定 义 、 数 据 操作 验证 、 撰 写 设计 报告 

















社 ， 
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【摘要 】 书 店 进 销 存 系统 是 根据 需求 主要 完成 对 书店 的 管理 和 销售 ， 包 括 书 籍 入 库 、 
销售 、 盘 存 、 顾 客 积分 等 。 系 统 可 以 提供 相关 信息 的 浏览 、 查 询 、 插 入 、 删 除 等 功能 。 系 
统 的 关键 是 采购 、 库 存 、 销 售 三 者 之 间 的 关系 ， 当 完成 入 库 或 销售 操作 时 系统 会 自动 完成 
库存 的 修改 。 查询 功能 也 是 系统 的 核心 功能 之 一 , 系统 可 以 根据 用 户 的 需要 进行 各 类 查询 。 
系统 数据 库 设 计 采 用 Microsoft SQL Server 2012。 系 统 易于 维护 ， 易 于 扩充 。 


【关键 词 】 数 据 库 设计 ， 书 店 ， 进 销 存 ，SQL Server 








Abstract: Bookstore purchase-sale-storage system is mainly based on the needs of the 


bookstore management and sales, including book storage, sales, inventory, customer points and 


so on. The system can provide functions such as browsing, querying, inserting, and deleting 
related information. The key to the system is the relationship among procurement, inventory, and 
sales. The system will automatically complete the inventory modification when the storage or 
sales operations are completed. The query function ls also one of the core functions of the system, 
The system can perform various types of queries according to the needs of users. The system 
database design adopts Microsoft SQL Server 2012. The system is easy to maintain and easy to 
expand. 


Key Words: Database Design, Bookstore, Purchase-sale-storage, SQL Server 
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引 


计算 机 的 普遍 应 用 对 人 类 文明 社会 的 进步 与 发 展 产生 了 深刻 影响 ， 越 来 越 多 的 单位 将 
计算 机 技术 应 用 于 日 常 的 事务 管理 工作 。 运 用 计算 机 技术 进行 管理 ， 不 仅 可 以 使 管理 工作 
规范 化 、 系 统 化 、 自 动 化 ， 而 且 可 以 节省 大 量 的 人 力 、 物 力 。 因 此 ， 数 据 库 管理 系统 越 来 
越 受到 人 们 的 青睐 。 

小 型 书店 进 销 存 系统 是 一 个 由 人 和 计算 机 组 成 的 ， 能 够 提供 信息 以 支持 一 个 组 织 机 构 
进行 作业 管理 、 分 析 和 决策 的 系统 。 进 销 存 系统 有 助 于 方便 地 管理 书店 的 经 营 状 况 ， 进 货 、 
退货 、 销 售 、 库 存 等 业务 管理 分 明 。 开 发 书店 进 销 存 管理 系统 不 仅 可 节约 时 间 ， 还 能 增强 
货物 的 流动 性 ， 具 有 较 强 的 使 用 价值 和 社会 价值 。 

















第 1 章 “需求 分 析 


1.1 处理 对 象 及 组 织 


针对 小 型 书店 进 销 存 系统 ， 分 别 对 采购 、 销 售 、 库 存 等 环节 进行 资料 查询 、 同 学 交流 ， 
总 结 出 以 下 需求 信息 。 
采购 : 书籍 在 固定 的 几 个 供应 商 采 购 ， 并 且 一 种 书 只 在 一 个 供应 商 采 购 ， 购 进 的 书籍 如 
检查 不 合格 可 以 进行 退货 。 
销售 : 顾客 可 以 根据 书籍 进行 单价 、 库 存 查 询 ， 但 不 能 查询 进 价 等 内 部 信息 ， 顾 客 若 发 
现 书籍 不 合适 ， 也 可 进行 退货 ， 不 损坏 全 额 退 款 ， 损 坏 不 予 退 货 。 
库存 : 商品 按 类 存放 ， 一 种 书 只 能 放 在 一 个 仓库 里 ， 一 个 仓库 可 以 存放 多 种 书 。 
因此 ， 小 型 书店 进 销 存 管理 系统 处 理 的 数据 对 象 主要 有 3 种 ， 每 种 包含 若干 数据 项 。 
具体 如 下 所 示 。 
e 书籍 ， 书号 、 书 名 、 售 价 、 作 者 、 出 版 社 、 进 价 、 库 存量 。 
e 供应 商 : 供应 商号 、 供 应 商 名 、 供 应 商 电 话 。 
e 仓库 : 仓库 号 、 库 存 名 、 面 积 、 地 址 。 


1.2 信息 处 理 及 系统 功能 





小 型 书店 进 销 存 系统 包含 书籍 信息 模块 、 供 应 商 信息 模块 、 仓 库 信 息 模块 ， 并 要 求 能 
实现 对 书籍 的 进 销 存 管理 及 增删 改 操作 。 系 统 主要 功能 如 图 1 所 示 。 


1.3 数据 库 系 统 性 能 需要 


系统 要 能 在 小 型 书店 中 应 用 ， 对 进 销 存 进行 完善 的 管理 ， 能 为 用 户 节约 成 本 和 时 间 ， 
并 提供 便利 管理 ， 使 采购 、 销 售 、 库 存 等 环节 有 序 。 


1.4 数据 库 系 统 开发 环境 需求 


采用 功能 强大 的 Microsoft SQL Server 2012 为 开发 工具 。 

















“1. 





第 9 章 课程 设计 实例 


小 型 书店 进 销 存 系统 














到 洲 锥 二 [一 


















































站 赃 到 类 门 








图 1 系统 功能 结构 图 


1.5 需求 分 析 阶 段 成 果 


1.5.1 数据 流 图 


35s 


数据 流 图 是 结构 化 分 析 最 基本 的 工具 ， 描 述 的 是 系统 的 分 解 ， 即 描述 系统 由 哪儿 部 分 


组 成 ， 各 部 分 之 间 有 什么 联系 等 。 


数据 流 图 描述 的 是 系统 的 逻辑 模型 ， 图 中 没有 任何 具体 的 物理 元 素 


统 中 的 流动 和 处 理 情况 。 
1. 顶层 数据 流 图 (如 图 2 所 示 ) 





仓库 管理 员 





图 2 顶层 数据 流 图 


i th 
销售 音 \ 发 代 单 ““ 








丰 述 信息 在 系 


供应 商 
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2. 第 0 层 数据 流 图 (如 图 3 所 示 ) 


订货 单 


退 书 回 单 书籍 销 售 ba 退货 单 


库存 台 账 





图 3 第 0 层 数据 流 图 
3. 第 1 层 数据 流 图 (如 图 4 ~ 图 6 所 示 ) 


[pr | 库存 台 帐 


购书 单 退 书 音 


销售 单 退 书 回音 





D3 | 缺 书 单 D2 | 销售 清单 D4 | 退 书 单 


图 4 第 1 层 数据 流 图 (销售 ) 





D3| 缺 书 单 D1| 库存 台 账 
订货 单 (0 信息 a 
:合格 合格 书 清单 


5 | 采购 清单 
退货 音 

















退货 回音 退货 清单 
图 5 第 1 层 数据 流 图 (采购 ) 


。3。 
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回 退 书 单 合格 书 清单 D2| 销售 清音 

















| D8| 入 库 单 D1 | 库存 台 账 出 库 单 








图 6 第 1 层 数 据 流 图 (出 入 库 ) 


1.5.2 ”数据 字典 


数据 字典 是 进行 详细 的 数据 收集 和 数据 分 析 所 获得 的 主要 成 果 。 它 是 关于 数据 库 中 数 
据 的 描述 ， 即 元 数据 ， 而 不 是 数据 本 身 。 数 据 字典 在 需求 分 析 阶 段 建立 ， 在 数据 库 设 计 过 
程 中 不 断 修改 、 充 实 、 完 善 ， 在 数据 库 设计 中 占有 很 重要 的 地 位 。 

数据 字典 通常 包括 数据 项 、 数 据 结构 、 数 据 流 、 数 据 存 储 和 数据 加 工 几 个 部 分 。 其 中 ， 
数据 项 是 数据 的 最 小 组 成 单位 ， 数 据 字典 通过 对 数据 项 和 数据 结构 的 定义 来 描述 数据 流 、 
数据 存储 的 逻辑 内 容 。 


1. 数据 项 


数据 项 是 不 可 再 分 的 数据 单位 ， 对 数据 项 的 描述 通常 包括 以 下 内 容 : 数据 项 编号 、 名 
称 及 含义 ， 数 据 类 型 和 长 度 ， 取 值 范围 等 。 进 销 存 系统 各 数据 项 描述 如 表 1 所 示 。 





表 1 数据 项 


数据 项 编号 取信 范围 

书籍 信息 表 

图 书 编号 

图 书 名 称 Char(20) 

图 书 单价 Int 

图 书 作 者 Char(6) 

图 书 出 版 社 Char(20) 

供应 商 编号 
顾客 信息 表 

顾客 编号 


CLevel 积分 
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数据 项 编号 | ”数据 项 名 称 数据 项 含义 数据 类 型 及 长 度 
顾客 购书 表 
BuyID 订单 编号 Char(20) 
CID 顾客 编号 Char(20) 
BID 图 书 编号 Char(20) 
BuyNum 购买 量 




















BuyDay 购买 日 期 





ReNum 


BuyMoney 
WD 


TTT ET 
出 了 量 [mm | 











出 库 时 间 
供应 商 信息 表 
| sp | 供应 商 编号 


供应 商 电话 Char(12) 
采购 表 














Char(20) 





Int 
Char(10) 
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2. 数据 结构 


数据 结构 反映 了 数据 之 间 的 组 合 关 系 。 一 个 数据 结构 可 以 由 若干 数据 项 组 成 ， 也 可 由 
若干 数据 结构 组 成 ， 或 由 若干 数据 项 和 数据 结构 混合 组 成 。 对 数据 结构 的 描述 通常 包括 以 
下 内 容 : 数据 结构 编号 、 数 据 结构 名 、 数 据 结构 含义 、 数 据 结构 组 成 等 。 进 销 存 系统 的 数 
据 结构 描述 如 表 2 所 示 。 

















表 2 数据 结构 

数据 结构 含义 数据 结构 组 成 

顾客 信息 CID, Cname, CLevel 

书籍 信息 BNO, Bname, BWriter, BPrice 

仓库 信息 KCID, Area, Address 
BuyID, BID, BuyNum, CID, BuyDay 
WID, ReNum, BuyMoneyBuy 

DS-5 采购 (供应 ) 信 息 BID, SID, InTime, Innum, WID 

DS-6 存储 信息 LossesNo, KCID, BID, CGnum, InNum 

DS-7 供应 商 表 SID, Sname, Phone 

DS-8 退货 信息 BNO，Tnum 

DS-9 入 库 信息 RkID, BID, InTime, InNum 

DS-10 出 库 信息 OutkID, BID, OUTTime, OutNum 


3. 数据 流 

数据 流 是 数据 结构 在 系统 内 传输 的 路 径 。 对 数据 流 的 描述 通常 包括 以 下 内 容 : 数据 流 
编号 、 数 据 流 名 称 、 简 述 、 数 据 流 来 源 、 数 据 流 去 向 、 数 据 流 组 成 和 流通 量 。 进 销 存 系统 
的 数据 流 如 表 3 所 示 。 








购买 信息 











表 3 数据 流 
数据 


流量 
时 


数据 流 组 成 





书店 向 供应 商 订购 商 书号 + 供应 商号 + 员工 号 + 
品 的 订货 单 供应 量 
供应 商 发 出 的 收 货 单 | 供应 , 让 号 + 员工 号 + 部 议 衣 
供应 量 
采购 部 验 货 不 合格 单 | 验 货 模块 | 退货 模块 | 仓库 号 + 书号 + 不 合格 数量 | 30 次 /月 
库 管 员 开 出 的 退货 单 书号 + 退货 数量 30 次 /月 
采购 部 验 货 合格 单 ”| 验 货 模 块 | 入 库 模块 | 书号 + 仓库 号 + 合格 数量 | 30 次 /月 
库 管 员 开 出 的 入 库 单 | 入 库 模 块 | 库存 台 账 | 书号 + 仓库 号 + 入 库 数量 |30 次 /月 
书号 + 仓库 号 + 现 有 库存 


现 有 库存 单 采购 模块 | ， > 30 次 /月 
数量 


30 次 /月 
































数据 流 | ”数据 流 流 | 数据 流 
I 简 述 3 
编号 名 称 去 向 


数据 


流量 
关 星 


数据 流 组 成 





F8 缺 货 单 销售 员 开 出 的 缺 货 单 


书号 + 缺 货 数量 30 次 /月 





F9 订单 顾客 列 出 的 购买 清单 


书号 + 书 名 + 数量 + 单价 30 次 /月 





销售 单 书店 向 顾客 的 反馈 单 


仓库 管理 员 填 写 的 货 | 货物 出 库 
物 出 库 记 录 模块 





出 库 音 


书号 + 书 名 + 数量 + 单价 + 总 价 | 30 次 /月 


书号 + 书 名 + 数量 + 仓库 号 ”|30 次 /月 





顾客 因 书 问题 向 书店 | ， > 


ee 
顾客 旭 货 间 | 提交 的 退 书 音 


书号 + 退货 数量 30 次 /月 





顾客 退货 并 被 受理 后 


形成 的 退货 信息 单 


上 号 + 退货 数量 30 次 /月 





| 因 销 售 、 退 货 等 引起 | ,| ss nm 
库存 清单 库存 变化 的 清单 库存 统计 | 库存 清单 





- 数据 存储 





数据 存储 是 数据 结构 停留 或 保存 的 地 方 ， 也 是 数据 流 
工 文档 或 手工 任 单 ， 也 可 以 是 计算 机 文档 。 对 数据 存储 的 
储 编号 及 名 称 、 数 据 存储 组 成 等 。 进 销 存 系统 的 数据 存储 


表 4 数据 存储 
数据 存储 编号 
库存 台 账 库存 记录 情况 清单 
销售 清单 销售 情况 记录 单 

顾客 购买 书籍 时 ， 发 现 缺 货 
的 信息 
退 忆 单 


采购 清单 对 缺 书 进行 集中 采购 的 依据 





名 号 + 仓库 号 + 现 有 库存 量 |30 次 /月 











的 来 源 和 去 向 之 一 。 它 可 以 是 手 
萌 述 通常 包括 以 下 内 容 : 数据 存 
如 表 4 所 示 。 


数据 存储 组 成 
仓库 号 + 书号 + 库存 数量 
订单 号 + 书号 + 顾客 号 + 数量 
订单 号 + 书号 + 缺 书 数量 
顾客 号 + 书号 + 退 书 数量 + 退 款 金额 
供应 商号 + 书号 + 数量 





退货 清单 采购 的 书籍 不 合格 情况 记录 


供应 商号 + 书号 + 数量 + 退 款 金额 





合格 书 清单 采购 检验 合格 的 数据 情况 


供应 商号 + 书号 + 数量 





入 库 单 采购 回来 放 到 仓库 的 书 


号 + 仓库 号 + 入 库 数量 








出 库 单 仓库 发 货 单 
5. 数据 加 工 
数据 加 工 是 对 基本 加 工 处 理 逻 辑 的 定义 ， 是 对 数据 流 





书号 + 仓库 号 + 数量 + 单价 


图 的 补充 ， 实 际 上 是 “加 工 小 说 


明 ” 对 数据 加 工 的 描述 通常 包括 以 下 内 容 : 处 理 逻 辑 编号 及 名 称 、 简 述 、 输 入 /输出 的 数 
据 流 、 处 理 描 述 、 处 理 频率 等 。 进 销 存 系统 的 数据 加 工 如 表 5 所 示 。 
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处 理 








销售 部 购买 书籍 











退 书 服务 | 顾客 因为 书籍 问题 退货 


购书 单 


根据 购书 单 向 顾客 销 
售 书籍 
确认 退货 


销售 记录 ， 
缺 书记 录 
退 书 信息 


15 次 /月 


15 次 /月 





依据 缺 书 情况 向 出 版 社 
订 书 


根据 清单 确 采 购书 籍 


采购 音 


15 次 /月 





对 采购 的 书籍 进行 检验 


检验 不 合格 退货 


不 合格 书 单 


根据 发 货 单 检验 商品 


确定 退货 


不 合格 书 单 ， 
合格 书 单 
退货 和 


15 次 /月 


15 次 /月 





书籍 入 库 


合格 书 单 ， 
退货 单 


登记 库存 账目 和 流水 


入 库 单 


15 次 /月 





仓库 根据 顾客 需求 发 货 





销售 清 


查找 库存 ， 有 货 出 库 








出 库 








15 次 /月 
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第 2 章 ”数据 库 结 构 设 计 


数据 库 结 构 设计 主要 包括 概念 结构 设计 和 逻辑 结构 设计 两 个 部 分 。 


2.1 概念 结构 设计 


在 进行 数据 库 设 计时 ， 是 先 将 现实 世界 中 的 客观 对 象 抽 象 为 不 依赖 任何 具体 计算 机 的 
信息 系统 。 数 据 库 概念 设计 的 目标 就 是 要 产生 反映 企业 组 织 信息 需求 的 数据 库 概念 结构 ， 
即 概念 模型 , 而 后 再 把 概念 模型 转化 为 具体 计算 机 上 计算 机 信息 管理 系统 支持 的 相关 模型 。 
概念 模型 是 独立 于 数据 库 的 逻辑 结构 , 独立 于 支持 数据 库 的 DBMS, 不 依赖 于 计算 机 系统 。 

概念 模型 是 表达 概念 设计 结果 的 工具 ， 具 有 以 下 主要 特点 。 

1. 能 真实 、 充 分 地 反映 现实 世界 ， 包 括 事物 和 事物 之 间 的 联系 ， 能 满足 用 户 对 数据 的 
处 理 要 求 ， 是 对 现实 世界 的 一 个 真实 模型 。 

2. 简洁 、 明 晰 、 易 于 理解 ， 且 独立 于 计算 机 ， 方 便 数 据 库 设计 人 员 和 应 用 人 员 进 行 交 
流 ， 用 户 的 积极 参与 是 数据 库 设计 成 功 的 关键 。 

3. 易于 变动 , 便于 修改 , 当 应 用 环境 和 应 用 要 求 改 变 时 , 容易 对 概念 模型 修改 和 扩充 。 

4. 易于 向 关系 、 网 状 、 层 次 等 各 种 数据 模型 转换 ， 方 便 地 导出 与 DBMS 有 关 的 多 辑 


概念 模型 有 多 种 ， 其 中 最 常用 的 是 “实体 一 联系 模型 ”(Entity Relationship ModeD)， 即 
使 用 E-R 图 来 描述 某 一 组 织 的 概念 模型 。 概 念 结构 设计 的 目标 即 抽象 出 系统 的 概念 模型 ， 
为 下 一 步 做 准备 。 该 阶段 的 任务 为 采用 自 下 而 上 的 方法 抽象 出 各 子 模块 的 E-R 图 ， 再 通过 
合并 的 方法 做 到 各 子 系统 实体 、 属 性 、 联 系 的 统一 ， 最 终 形成 系统 的 全 局 E-R 图 。 


2.1.1 局 部 E-R 


局 部 E-R 图 建立 的 思想 是 以 中 间 层 数据 为 切入 点 ， 按 照 分 层次 /分 模块 的 思想 ， 用 E-R 
模拟 描述 。E-R 图 中 各 形状 符号 代表 的 意义 如 图 7 所 示 。 


图 7 E-R 图 符号 





注 : 这 里 指定 ， 顾 客 购买 的 书籍 就 是 书店 销售 出 去 的 书籍 ， 供 应 商 供应 的 书籍 就 是 书 
店 采购 部 采购 的 书籍 。 
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1. 实体 及 属性 E-R 图 
进 销 存 系统 中 主要 的 实体 为 : 顾客 、 书 籍 、 供 应 商 和 仓库 ， 各 实体 及 属性 的 E-R 区 





图 8 实体 及 属性 E-R 图 


2. 进 销 存 系统 的 局 部 E-R 


经 分 析 ， 该 进 销 存 系统 存在 4 个 局 部 E-R 图 ， 如 图 9 所 示 。 























入 库 单 


























图 9 局 部 E-R 图 
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2.1.2 全 局 E-R 














在 开发 一 个 大 型 信息 系统 时 ， 最 经 常 采用 的 策略 是 自 项 向 下 地 进行 需求 分 析 ， 然 后 再 
底 向 上 地 设计 概念 结构 。 即 先 设计 各 子 系统 的 局 部 E-R 图 ， 然 后 将 它们 集成 起 来 ， 得 到 
全 局 E-R 图 。E-R 图 的 集成 一 般 需 要 分 为 以 下 两 步 。 

(1) 合并 。 解决 局 部 分 E-R 图 之 间 的 冲突 ,将 局 部 E-R 图 合并 起 来 ， 生成 初步 E-R 图 。 
(2) 修改 和 重 构 。 消 除 不 必要 元 余 ， 生 成 基本 E-R 图 。( 规 范 化 理论 ) 
根据 上 述 两 步 ， 生 成 进 销 存 系统 的 全 局 E-R 图 ， 如 图 10 所 示 。 














图 10 全 局 E-R 图 
2.2 ”逻辑 结构 设计 


逻辑 结构 设计 的 任务 就 是 把 概念 结构 设计 阶段 设计 好 的 全 局 E-R 图 转换 为 与 选用 的 
DBMS 产品 所 支持 的 数据 模型 相符 合 的 逻辑 结构 。E-R 图 向 关系 模型 的 转换 要 解决 的 问题 
是 , 如 何 将 实体 型 和 实体 之 间 的 联系 转换 为 关系 模式 , 如 何 确定 这 些 关 系 模式 的 属性 和 码 。 

E-R 图 转换 为 关系 模型 实际 上 是 将 实体 型 、 实 体 的 属性 和 实体 之 间 的 联系 转换 为 关系 
模式 ， 转 换 原则 如 下 。 

(1) 一 个 实体 型 转换 为 一 个 关系 模式 ， 关 系 的 属性 就 是 实体 的 属性 ， 关 系 的 码 就 是 实 
体 的 码 。 

(2) 对 于 实体 型 间 的 联系 则 根据 不 同 的 情况 进行 转换 。 

@ 一 个 1 : 1 联系 可 以 转换 为 一 个 独立 的 关系 模式 ， 也 可 以 与 任意 一 端 对 应 的 关系 模 
式 合 并 。 

@ 一 个 1 :mn 联系 可 以 转换 为 一 个 独立 关系 模式 ， 也 可 以 与 N 端 对 应 的 关系 模式 合并 。 

@ 一 个 m:n 联系 转换 为 一 个 关系 模式 。 

@ 3 个 或 3 个 以 上 实体 间 的 一 个 多 元 联系 可 以 转换 为 一 个 关系 模式 。 

@ 具有 相同 码 的 关系 模式 可 合并 。 
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2.2.1 建立 关系 模式 


关系 模式 表示 形式 为 R(U, F), 下 面 将 书店 进 销 存 系统 的 全 局 E-R 图 转换 为 关系 模式 。 
关系 的 码 用 下 划 线 标 出 。 

购买 单 (订单 号 ， 书 名 ， 购 买 量 ， 购 买 日 期 ， 总 费用 ) 

购买 (书号 ， 顾 客 号 ， 购 买 量 ， 购 买 日 期 ) 

退 书 单 ( 退 书 单 号 ， 书 名 ， 退 书 数量 ) 

退货 ( 退 书 单 号 ， 书 号 ， 退 货 量 ) 

书籍 (书号 ， 书 名 ， 书 单价 ， 作 者 ， 出 版 社 ) 

供应 商 (供应 商号 ， 供 应 商 名 ， 供 应 商 电 话 ) 

采购 /供应 (供应 商号 ， 书 号 ， 供 应 量 ， 进 价 ， 采 购 日 期 ) 

仓库 (仓库 号 ， 面 积 ， 所 在 地 ) 

存储 (仓库 号 ， 书 号 ， 库 存量 ) 

顾客 (顾客 号 ， 姓 名 ， 积 分) 

入 库 单 (入 库 单 号 ， 书 号 ， 入 库 量 ， 入 库 时 间 ) 


2.2.2 关系 模式 规范 化 处 理 


数据 库 逻 辑 设计 的 结果 不 是 唯一 的 。 为 了 进一步 提高 数据 库 应 用 系统 的 性 能 ， 还 应 该 
根据 应 用 需要 适当 修改 、 调 整数 据 模型 的 结构 ， 这 就 是 数据 模型 的 优化 。 关 系数 据 模型 的 
优化 通常 以 规范 化 理论 为 指导 。 

根据 规范 化 理论 , 分 析 每 一 个 关系 模式 是 否 满足 3NF， 对 不 满足 3NF 的 关系 模式 要 进 
行规 范 化 处 理 。 


2.2.3 ”用 户 子 模式 建立 


将 概念 模型 转换 为 全 局 逻辑 模型 后 ， 还 应 该 根据 局 部 应 用 需求 ， 结 合 具体 关系 数据 库 
管理 系统 的 特点 ， 设 计 用 户 的 子 模式 。 用 户 子 模式 表示 形式 为 ， 子 模式 名 (属性 列表 )。 

对 于 购书 单 这 一 关系 模式 ， 由 于 顾客 和 管理 者 都 需要 知道 其 中 的 各 个 属性 ， 故 只 需要 
建立 一 个 视图 : 购书 单 视图 (图 书 编号 ， 购 书 单 编号 ， 购 书 数量 ， 购 书 日 期 )。 

在 图 书 关系 上 ， 可 以 为 一 般 用 户 和 管理 者 分 别 建立 视图 。 

一 般 用 户 视图 : 图 书 视图 1( 书 名 称 ， 作 者 ， 出 版 社 ， 单 价 )。 

管理 者 视图 : 图 书 视 图 2 (图 书 编号 ， 供 应 商号 ， 书 名 称 ， 作 者 ， 出 版 社 ， 单 价 ， 所 存 
仓库 号 )。 

为 书店 进 销 存 系统 建立 的 用 户 子 模式 ， 如 表 6 所 示 。 
































视图 描述 作用 
名 单 (书号 ， 订 单 号 ， 购 书 数量 ， 购 书 日 期 ) 于 顾客 和 管理 员 对 购书 情况 的 查询 
电 1( 名 称 ， 作 者 ， 出 版 社 ， 单 价 ) 于 一 般 用 户 查询 图 书 的 详细 信息 
是 2( 书 号 ， 供 应 商号 ， 书 名 称 ， 作 者 ， 单 价 ， 
所 存 仓库 号 ) 
供应 商 (供应 商 编号 ， 供 应 商 名 ， 联 系 电话 ) 于 管理 者 对 供应 商 的 信息 查询 
管理 者 仓库 (仓库 编号 ， 库 存量 ) 于 管理 者 查询 仓库 信息 
库 管 员 存储 (仓库 编号 ,入 库 时 间 ， 库 存量 ) 于 库 管 员 和 管理 员 对 存放 情况 的 查询 
管理 者 供应 (供应 商 编号 ， 书 号 ， 供 应 量 ， 进 价 ) 于 管理 者 对 供应 情况 的 查询 


2.2.4 ”关系 模式 逻辑 结构 定义 














于 管理 者 对 图 书 的 详细 信息 查询 

















每 个 关系 模式 要 以 表格 形式 描述 其 具体 内 容 。 若 涉及 的 关系 模式 较 多 ， 可 以 在 正文 中 
先 用 表格 反映 关系 模式 名 称 、 含 义 和 备 注 (备注 指明 关系 模式 附录 编号 )。 进 销 存 系统 的 关 
系 模式 逻辑 结 构 定义 ， 如 表 7 所 示 。 


表 7 进 销 存 系统 的 关系 模式 逻辑 结构 定义 

关系 模式 名 称 含义 备注 
购买 (销售 ) 关 系 顾客 购买 书籍 的 信息 见 6.1 附录 1 表 9 
供应 (采购 ) 关 系 书店 采购 书籍 的 信息 见 6.1 附录 1 表 10 
供应 商 关系 供应 商 详细 信息 见 6.1 附录 1 表 11 
仓库 关系 仓库 详细 信息 见 6.1 附录 1 表 12 
入 库 关系 书籍 入 库 信息 见 6.1 附录 1 表 13 
书籍 关系 书籍 的 基本 信息 6.1 附录 1 表 14 
顾客 关系 顾客 的 详细 信息 6.1 附录 1 表 15 
顾客 退 书 关系 顾客 退 书 的 详细 信息 6.1 附录 1 表 16 
书店 退货 关系 书店 向 供应 商 退货 的 信息 6.1 附录 1 表 17 
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第 3 章 数据 库 物理 设计 


数据 库 物 理 设计 主要 包括 数据 存储 位 置 、 存 储 格式 、 索 引 及 索引 类 型 。 如 果 建 立 的 
索引 较 多 ， 最 好 以 表格 形式 列 出 ， 主 要 包括 索引 名 称 、 索 引 类 型 和 用 途 。 进 销 存 系统 建 
立 的 索引 如 表 8 所 示 。 


表 8， 进 销 存 系统 的 索引 表 
所 在 表 名 索引 名 称 索引 类 型 用 途 
供应 商 | sapme 唯一 | “查询 供应 商 信息 
书籍 信息 表 | Binfo 唯一 | 查询 书籍 信息 
仓库 信息 KCInfo 唯一 查询 仓库 信息 
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4.1 数据 库 实 施 


4.1.1 数据 库 及 数据 库 对 象 建立 


数据 库 及 数据 库 对 象 建立 主要 包括 数据 库 的 创建 、 基 本 表 的 创建 、 视 图 的 创建 、 索 引 
的 创建 、 触 发 器 的 创建 及 存储 过 程 的 创建 。 

对 于 具体 的 实现 DDL 语句 以 及 相关 代码 ， 以 附录 形式 列 出 ， 在 附录 2 中 详细 给 出 ， 
包含 创建 的 语句 、 结 果 截 图 、 测 试 截图 。 


4.1.2 数据 入 库 


根据 需求 ， 本 系统 共 创建 9 个 基本 表 ， 在 Excel 中 编辑 好 数据 后 ， 采 用 复制 粘贴 的 
方法 导入 ， 部 分 数据 违反 唯一 性 约束 ， 没 有 成 功 导入 ， 但 是 导入 成 功 的 数据 基本 足够 测 
试 使 用 。 


让 要 内 容 是 对 建立 的 数据 库 及 数据 库 对 和 象 进行 测试 。 
其 体 要 求 : 

1. 要 设计 好 测试 数据 。 

2. 对 测试 的 结果 要 以 图 片 形式 给 出 ， 同 时 注意 图 片 的 格式 。 
3. 对 测试 结果 进行 分 析 ， 是 否 满足 设计 要 求 。 

测试 过 程 语句 及 结果 截图 见 6.2 附录 2 数据 定义 语句。 
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第 5 章 








通过 1.5 周 的 数据 库 系统 原理 及 应 用 课程 设计 ， 我 对 数据 库 系 统 的 基本 理论 和 基本 知 
识 有 了 更 深 的 了 解 。 开 始 进行 需求 分 析 的 时 候 ， 关 于 如 何 画 数据 流 图 真 的 并 不 清楚 ， 只 是 
照 着 老师 PPT 上 的 图 进行 微小 的 变动 ， 但 这 样 画 下 来 也 费 了 不 少时 间 和 精力 。 到 后 来 画 
E-R 图 的 时 候 ， 才 发 现 照搬 老师 的 课件 ， 做 东西 会 有 点 麻烦 ， 于 是 自己 回 过 头 修改 基本 流 
星 图 。 画 E-R 图 的 时 候 ， 也 是 照 着 自己 心里 想 的 东西 画 ， 根 本 没 考虑 有 些 东西 在 流程 图 中 
无 法 出 现 。 设 计 表 、 编 写 程序 代码 语句 的 时 候 ， 遇 到 的 问题 也 很 多 ， 不 过 在 老师 和 同学 的 
帮助 下 ,都 基本 得 到 解决 。 当 在 SQL Server 2012 中 实现 功能 后 ,我 们 又 简单 学 了 一 下 Oracle， 
并 将 所 有 功能 移植 到 Oracle 中 实现 。 这 两 个 运行 环境 区 别 不 大 ， 编 写 的 视图 直接 复制 过 
来 就 能 运行 。 但 对 于 存储 过 程 和 触发 器 ， 两 者 区 别 还 挺 大 ， 于 是 在 保持 功能 不 变 的 前 提 
下 我 们 进行 了 重新 编写 。 

在 这 次 课程 设计 中 ， 对 数据 库 的 应 用 及 各 部 分 设计 过 程 有 了 更 深 的 了 解 ， 但 也 发 现 ， 
了 解 越 多 ， 发 现 不 懂 的 也 越 多 。 无 论 学 什么 ， 实 践 总 是 能 起 到 意料 之 外 的 作用 ， 但 曲折 归 
曲折 ， 最 终 还 是 基本 完成 了 设计 ， 虽 然 不 尽 完善 ， 但 是 雏形 还 是 有 的 。 

在 设计 过 程 中 ， 绘 制 数据 流 图 和 E-R 图 的 时 候 ， 使 用 了 亿 图 绘图 软件 ， 编 写 语句 时 ， 
使 用 了 SQL Server 2012 编译 环境 。 
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第 6 


章 ”附录 


6.1 附录 1 (书店 进 销 存 系统 ) 关 系 模式 汇总 


别名 


表 9 购买 关系 的 说 明 


数据 类 型 


是 否 为 外 码 





[= 
Ee] 


CHAR(20) 





顾客 号 


CHAR(20) 





六 





InTime 


InNum 


购买 量 


购买 日 期 


供应 商号 


采购 日 期 


供应 量 


别名 


INT 
| bammel| | | | 


表 1 


0 ”供应 关系 的 说 明 


CHAR(20) 
CHAR(C20 
DATETIME 


表 11 


供应 商 关系 的 说 明 





供应 商号 


供应 商 名 


CHAR(10， 


CHAR(8) 


取 值 范围 





供应 商 电 话 


CHAR(12 


表 1 


2 仓库 关系 的 说 明 
取 值 范围 | 是 否 为 主 码 





是 否 为 外 码 





污 
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表 13 入 库 关系 的 说 明 
别名 数据 类 型 是 否 为 外 码 
入 库 单 号 | CHAR(20) | NOT NULL 
书号 | CHAR(20) 滞 | NOTNULL 














入 库 时 间 | DATETIME | NULL 
入 库 量 








表 14 书籍 关系 的 说 明 











Bprice 
Press 

















库存 量 


是 否 为 外 码 
| | | 


顾客 号 CHARC0 


Cname 


Clevel 





表 16 顾客 退 书 关系 的 说 明 
数据 类 型 | 取 值 范围 | 是 否 为 主 码 
CHAR(20) Y 
CHAR(20) 

INT 











表 17 书店 退货 关系 的 说 明 
别名 是 否 为 外 码 
退货 单 号 
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6.2 ”附录 2 数据 定义 语句 


6.2.1 SQL Server 2012 中 创建 基本 表 


1. 创建 数据 库 
CREATE DATABASE BookStore 


2. 基本 表 的 创建 
(1) 创建 书籍 信息 表 


CREATE TABLE Book 

(BID CHAR(20) PRIMARY KEY. 
Bname CHAR(20) NOT NULL., 
Bprice FLOAT, 

Bwriter CHAR(12), 

Inprice FLOAT, 

KCID CHAR(10) NOT NULL., 
Press CHAR(20). 

KCNum INT CHECK(KCNum>0), 
CHECK (Inprice<Bprice) 

其 

(2) 创建 供应 商 表 


CREATE TABLE S 

(SID CHAR(10) PRIMARY KEY, 
Sname CHAR(8), 

Phone CHAR(12) 

六 

(3) 创建 仓库 表 

CREATE TABLE Ck 

(KCID CHAR(10) PRIMARY KEY. 
Area FLOAT, 

Address CHAR(10) 

E 

(4) 创建 顾客 表 


CREATE TABLE C 
(CID CHAR(20) PRIMARY KEY 
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Cname CHAR(8), 
Clevel FLOAT 


); 

(5) 创建 购买 关系 表 

CREATE TABLE Buy 

(BID CHARQO)NOT NULL, 

CID CHAR(20) NOT NULL, 

BuyNum INT, 

BuyDay DATETIME, 

FOREIGN KEY (BID) REFERENCES Book(BID), 
FOREIGN KEY (CID) REFERENCES C(CID), 
PRIMARY KEY(BID,CID) 

); 

(6) 创建 供应 表 

CREATE TABLE P 

(SID CHAR(10), 

BID CHAR(20), 

InTime DATETIME, 

InNum INT, 

FOREIGN KEY (SID) REFERENCES S(SID), 
FOREIGN KEY (BID) REFERENCES Book(BID), 
PRIMARY KEY(SID,BID) 

六 

(7) 创建 顾客 退 书 单 表 

CREATE TABLET 

(TID CHAR(8) ， 

BID CHAR(20)NOTNULL, 

TNum INT 

FOREIGN KEY (BID) REFERENCES Book(BID)， 
了 PRIMARY KEY(TID.BID) 

其 
(8) 创建 书店 退货 单 表 


CREAIE TABLE TH 

(THID CHAR(8) ， 

SID CHAR(20) NOT NULL， 

BID CHAR(20) NOTNULL， 

THNum INT, 

FOREIGN KEY (BID) REFERENCES Book(BID), 
PRIMARY KEY(THID.,SID.BID) 


» 


Jd 
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(9) 创建 入 库 单 表 


局 


CREATE TABLE RK 

(WID CHAR(20), 

BID CHAR(20) NOT NULL, 
InTime DAIETIME ， 
RKNum INT, 

PRIMARY KEY(WID,BID) 
); 


创建 后 的 基本 表 如 图 11 所 示 。 
6.2.2 ”SQL Server 2012 中 对 基本 表 的 增删 改 
(1) 在 C 表 中 插入 信息 ， 如 图 12 所 示 。 


INSERT 
INTOC 
VALUES(avaa'"100):; 


回 夯 加 四 四 男 面 四 时 洗 


[| 
护 
由 
田 
田 
由 
四 
由 
田 
国 
田 
田 

,Pa 


图 11 创建 的 基本 表 


半 昌 


图 12 插入 信息 


(2) 在 Book 表 中 删除 BID='200909040' 的 信息 。 
删除 前 如 图 13 所 示 。 


200909033 

» Ja009050%0 
200909101 
200909102 
200909104 
200909109 
200909119 
200909121 
200909127 
200909129 
200909135 
200909137 
200909139 

7 


< 
M4)s 124| Ho 


图 13 Book 表 删 除 操作 前 的 信息 


时 
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DELETE 
FROM Book 

WHERE BID='200909040'; 

执行 该 语句 删除 后 ， 表 由 24 行 变 成 了 23 行 ， 已 经 删除 该 信息 ， 如 图 14 所 示 。 

















200909034 车 马 畏 彩 杀 法 .… 高 文博 
200909033 营销 百事 通 杨 宗 航 
200909101 平凡 的 世界 誉 了 一 
200909102 计算 机 网 络 安 . 屠 铂 文 
200909104 Web 程 序 设计 .， 张涛 字 
200909109 医学 免疫 学 刘 董 博 
200909119 中 药 资源 教育 他 
200909121 战争 与 和 平 蝎 而 桐 
200909127 商业 研究 方法 ， 起 书 等 
200909129 进化 金融 理论 .,。 段 科 话 
200909135 应 用 写作 

200909137 品牌 百事 通 

200909139 天 下 名 物 大 观 

ML ALL 


Injb Hho 


图 14 Book 表 删 除 操作 后 的 信息 





(3) 对 S 表 进 行 修改 操作 。 
修改 前 如 图 15 所 示 。 


UPDATES 
SET Phone=1111 
WHERE SID=- 95008'; 


执行 该 语句 修改 后 ， 如 图 16 所 示 。 
|sD Sname 

[sso00 清雅 轩 

95001 各 书 已 见 | Sr 

95002 清风 阁 8709102 

文海 书屋 8709103 

书 虫 天 下 8709104 

畅 绰 斋 ? 8709105 

书 海 | 8709106 

竹林 书屋 8709107 


饮 书 间 L 111 
NL 


_Phone 


NLL 


图 15 S 表 修改 前 的 信息 S 表 修改 后 的 信息 


6.2.3 SQL Server 2012 中 创建 视图 


1. 建立 购书 单 视图 


CREATE VIEW BuyList_view 

AS 

SELECT Buy.BID.Bname,Buynum,BuyDay,(BuyNum * Bprice) Total 
FROM Buy ,Book 
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WHERE Buy BID=Book BID; 
查询 视图 : 


SELECT* 
FROM BuyList_view; 


from DuyList_vicw 


| -- 建 立 供 友 安村 询 图 书信 息 的 禄 图 


ByDay 
_] GC 语言 课程 设计 案例 20130701 00:00:00.000 
列宁 时 代 观 研究 2003.06.06 00:00-:00.000 
中 药 刺 区 辅料 应 用 这 2010.01.01 00:00.00.000 
本 草 纲目 2010-05-04 00:00:00.000 
少年 维特 之 烦恼 2011010100.00.00.000 
三 国 演义 2011-06-08 0000.00.000 
红 慷 末 2011-10-14 00-00:00.000 
当代 江苏 简 史 2012.09-16 00:00:00.000 
盏 庆 龙 与 国企 制胜 20130101000000000 
订 2013.06-15 00:00:00.000 
200303119 2010-08-09 00:00:00.000 
200909121 ”战争 与 和 平 2010-12-.05 00:00:00 000 
200503127 ”商业 研究 方法 2011-1230 00:00:00.000 
200305123 。 进化 全 融 理论 及 应 用 20120804 000000000 


图 17 购书 单 视图 


2. 建立 供 顾 客 查询 图 书信 息 的 视图 


CREATE VIEW BuyBook view 

AS 

SELECT Bname,BwriterBprice,Press 
FROM Book: 


查询 视图 : 

SELECT * 

FROM BuyBook view: 

操作 界面 结果 如 图 18 所 示 。 

3. 建立 供 管理 者 查询 图 书信 息 的 视图 


CREATE VIEW AdmBook view 

AS 

SELECT BookBID,Bname.Bprice,BwriterInprice 
FROM Book: 


查询 视图 : 
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SELECT* 
FROM AdmBook view: 


操作 界面 及 结果 如 图 19 所 示 。 


[一 建立 供 顾客 查询 图 书信 息 的 视图 


aelac= Bname, Surirer, aprice, press 
Erom accz 


-一 建立 供 管理 者 查询 列 书 信息 的 视图 
go 


se view AdnBcck ricw 























= 
中 国 丙 业 出 版 二 
让 国美 趟 出 版 二 
列 于 时 代 现 研 究 北京 册 拆 入 
中 蕴 相 区 本 村 夯 用 学 北京 邮包 村 
出生 入 
4 郴 出 版 
中 国美 不 出 版 秆 
中 国美 相册 版 让 | 
太 西 民 &K 大 学 出 版 村 和 语 训 音程 设计 村 沿 
秋天 与 王 企 制 和 b 埋 隐 理 大 学 出 生 社 2 天守 时 人 仙 研 究 
在 如 下 背 凶 渡 on 16 中 天 和 区 铺 科 应 用 学 
天 
二 从 姓 的 金 科 玉 委 中 国 it 版 让 
和 /Len 世界 -上海 文 2 版 号 守 
计 其 机 网 阁 安 主 林 而 订 帮 出 笑 中 必 
Wet 粒 厅 认 i 加 天 四国 回力 比 二 六 
医学 多 妆 学 人 民 吉 版 入 
中 英法 泊 禾 育 到 。 天 要 出 上 
战争 与 和 平 广西 册 弧 社 
商业 时 究 方法 1 生出 入 3 敌人 处 世 的 多 和 王 津 
进化 全 融 旦 论 及 外 用 。 算术 漠 52 中 山大 学 出 版 站 二 RE 也 界 的 


应 写作 社 生 。 太 中 山 二 学 出 版 二 计算 机 网 从 安全 去 础 35 





图 18 顾客 查询 图 书信 息 的 视图 图 19 管理 者 查询 图 书信 息 的 视图 


4. 建立 查询 供应 商 信息 的 视图 


CREATE VIEW AdmS view 
AS 

SELECT SID,Sname,Phone 
FROM S; 


查询 视图 : 

SELECT* 

FROM AdmS view: 
操作 界面 及 结果 如 图 20 所 示 。 
5. 建立 仓库 信息 的 视图 
CREATE VIEW KC view 

AS 


SELECT KCID,Area,Address 
FROM Ck: 


查询 视图 : 


SELECT* 
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FROM KC view:; 
操作 界面 及 结果 如 图 21 所 示 。 


立 查 鹿 供 应 商 信息 的 视图 -- 建 立 仓 库 信息 的 视图 
go 


create view KC view 
select KCID, Area, Mdress 
| seem cx 





北 区 


图 20 查询 供应 商 信息 的 视图 图 21 仓库 信息 视图 
6. 建立 缺 货 单 视 图 


CREATE VIEW QH view 
AS 

SELECT BID,Bname 
FROM Book 

WHERE KCNum=0; 


查询 视图 : 


SELECT* 
FROM QH view: 


操作 界面 及 结果 如 图 22 所 示 。 


一 建立 缺 货 单 视图 


g 


图 22 缺 货 单 视图 
6.2.4 SQL Server 2012 中 创建 存储 过 程 


1. 建立 查询 的 存储 过 程 


CREATE PROCEDURE pl_query Adm-- 查 询 指定 书籍 有 无 库存 
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@Bname CHAR(20) 

AS 

SELECT KCNum 

FROM Book 

WHERE Bname=@Bname: 


执行 存储 过 程 : 
EXEC pl_query Adm ' 本 草 纲目 ' 
操作 界面 如 图 23 所 示 。 


-建立 查 鹿 的 存 情 过 得 
"本 询 的 定 书 辆 有 无 库存 


图 23 建立 查询 的 存储 过 程 
2. 建立 插入 销售 (购买 ) 信 息 的 存储 过 程 


CREATE PROCEDURE BuyList_insert-- 插 入 销售 (购买 ) 信 息 
@BID CHAR(20), 

@CID CHAR(20), 

@Buynum INT, 

@BuyDay DATETIME 

AS 

INSERT INTO Buy 
VALUES(@BID,@CID,@Buynum,@BuyDay); 


执行 存储 过 程 : 
EXEC BuyList_insert '200909038','9,1,2012-12-12'; 


操作 界面 如 图 24 所 示 。 


YList_inserc/* 插 入 销售 购买 ) 信息 * 


1 行 委 虹 响 


图 24 插入 销售 (购买 ) 信 息 的 存储 过 程 
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3. 建立 插入 供应 (采购 ) 信 息 的 存储 过 程 


CREATE PROCEDURE P_insert-- 插 入 供应 (采购 ) 信 息 
@PID CHAR(20)， 

@SID CHAR(20), 

@BID CHAR(10), 

@InTime DATETIME, 

@ImNum INT 

AS 

INSERT INTOP 
VALUES(@PID,@SID,@BID,@InTime,@InNum): 


执行 存储 过 程 : 
EXEC P_insert 'P25"'95000',200909121"'2013-1-1",100; 
操作 界面 如 图 25 所 示 。 


Did 


图 25 插入 供应 (采购 ) 信 息 的 存储 过 程 


6.2.5 SQL Server 2012 中 创建 触发 器 


1. 进货 后 在 库存 表 中 更 新 记录 的 触发 器 


CREATE TRIGGER tr P_Store 

ON PAFTER INSERT 

AS 

DECLARE @InNum INT.@BID CHAR(20) 
SELECT QImNun=ImNumQ@BID=BID 
FROM INSERIED 

UPDAIE Book 
SETKCnumn=KCnum+OInNum 

WHERE BId=@BID; 


验证 该 触发 器 : 
INSERT 
INTOP 
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VALUES (‘pa','95002''200909121','2013-1-2',10); 


操作 界面 如 图 26 所 示 。 


本 
有 





E73 
人 行 妥 影响 ) 
行 委 时 响 


图 26 进货 后 在 库存 表 中 更 新 记录 的 触 后 器 


更 新 执行 前 的 记录 信息 如 图 27 所 示 。 


计划 机 同安 .… 
Web 程序 设计 ，… 


天 下 名 物 大 观 ,，62 
Mu 


I 4 slp Hs 
图 27 更 新 执行 前 的 记录 信息 


更 新 执行 后 的 记录 信息 如 图 28 所 示 。 
ES 程序 有 计 。 
200309109 医学 免疫 学 

| ja 中 药 资 源 教育 
200909121 。。 战争 与 和 平 
200909127 商业 研究 方法 … 
200809129 进 炒 金融 理论 … 
jzomo9135 应 乃 作 
ee 品牌 百事 天 5 
| 200309139 天 下 名 物 大 观 .，62 
# | AL 


图 28 更 新 执行 后 的 记录 信息 
2. 销售 图 书后 在 存储 表 中 更 新 记录 的 触发 器 


CREATE TRIGGER tr Buy_Save 


系 太 出 版 中 心 了 
中 国电 办 出 版 

人 人 民 教 育 出 版 ,。 2 
天 极 出 版 术 
厂 西 出 版 村 

重庆 出 版 村 

中 山大 学 版。 

中 山大 学 出 版 

中 山大 学 出 版 

中 山大 学 出 版 
MU 


中 国电 力 出 版,,， 
人 民 教 育 出 版 ,,， 


天 极 出 版 柱 
广西 出 版 村 
重庆 出 版 杜 


中 山大 学 出 版 ,,， 
中 山大 学 出 版 ， 
中 山大 学 出 版 ,,， 


中 山大 学 出 上 
MAL 


-Ils 
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ON Buy AFTER INSERT 

AS 

DECLARE @BID CHAR(20) ,@CID CHAR(20).@BuyNum INT,@BuyDay DATETIME 
SELECT @BuyNum=INSERIED.BuyNum ,@BID=Book.BID 

FROM INSERTED,Book 

WHERE BookBID=INSERTED.BID 

UPDATE Book 

SETKCnum=KCnum-Q@BuyNum 

WHERE BookBID=Q@BID: 


验证 该 触发 器 : 

INSERT 

INTO Buy 
VALUES(200909139','29',27,'2013-6-6"); 
操作 界面 如 图 29 所 示 。 


“~- 销 售 图 书后 在 存储 表 中 更 新 记录 的 触发 吕 


srt, 9ayDay davetime 


: 行 要 影响 ; 
行 受 紧 啊 ) 
: 2 


图 29 销售 图 书后 在 存储 表 中 更 新 记录 的 触发 器 


更 新 执行 前 的 记录 信息 如 图 30 所 示 。 
Louzuzaea 由 mmszbi， J 人 oa TAT Me 
200909135 应 用 写作 76 安 社 臣 中 山大 学 出 版 ， 
品牌 百事 通 7 宁 明 至 中 山大 学 出 版 .,。 
天 下 名 物 大 观 ,.，62 李 正 彭 中 山大 学 出 版 .,， 


NUL NU NL NL NU 


图 30 更 新 执行 前 的 记录 信息 


更 新 执行 后 的 记录 信息 如 图 31 所 示 。 


200909135 应 用 写作 而 安 社 臣 中 山大 学 出 版 … 

|200909137 吕 牌 百事 通 7 宋 明 至 中 山大 学 出 版 ， 

] 天 下 名 物 大 观 .62 Ea 中 山大 学 出 版 
ML MUL MLL ML 


图 31 更 新 执行 后 的 记录 信息 
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3. 修改 顾客 积分 信息 


CREATE TRIGGER tr CLevel 

ON Buy AFTER INSERT 

AS 

DECLARE @BID CHAR(20) ,@CID CHAR(20),@BuyNum INT,@Bprice FLOAT 

SELECT @BuyNum=INSERTED.BuyNum, @CID=INSERTED.CID,(@BId=INSERTED.BID, 
@Bprice=Bprice 

FROM INSERTED,Book 

WHERE Book.BID=INSERTED.BD 

UPDATE CC 

SET CLevel=CLevel+@BuyNum*@Bprice 

WHERE C.CID=@CID: 


验证 该 触发 器 : 

INSERT 

INTO Buy 
VALUES('200909012'"10',1,2013-1-1"); 
操作 界面 如 图 32 所 示 。 
插入 的 数据 ， 如 图 33 所 示 。 
触发 器 生效 前 的 信息 如 图 34 所 示 。 
触发 器 生效 后 的 信息 如 图 35 所 示 。 


| em 


2013.01-0100:， 
2013010100:... 
Mu 


Cname 
刘 睁 

Ca 711 放 叶 再 
1 125 1 胡言 125 


图 34 触发 器 生效 前 的 信息 图 35 触发 器 生效 后 的 信息 
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致 谢 


经 过 了 10 天 的 努力 ， 我 最 终 完 成 了 课程 设计 。 从 开始 选 题 到 系统 的 实现 ， 再 到 设计 
报告 的 撰写 , 每 走 一 步 对 我 来 说 都 是 新 的 尝试 与 挑战 。 在 这 段 时 间 里 , 我 学 到 了 很 多 知识 ， 
也 有 很 多 感受 ， 从 一 无 所 知 ， 开 始 了 独立 的 学 习 和 试验 ， 查 看 相关 的 资料 和 书籍 ， 让 自己 
头脑 中 模糊 的 概念 逐渐 清晰 ， 使 自己 十 分 稚嫩 的 作品 一 步 步 完 善 起 来 ， 每 一 次 完善 都 是 学 
习 的 收获 ， 每 一 次 试验 的 成 功 都 会 让 我 兴奋 好 一 段 时 间 。 

我 的 作品 不 是 很 成 熟 ， 还 有 很 多 不 足 之 处 ， 但 是 这 次 设计 的 经 历 使 我 终身 受益 。 我 感 
受到 做 设计 是 要 真 真正 正 用 心 去 做 的 一 件 事情 ， 是 真正 自己 学 习 和 研究 的 过 程 。 没 有 学 习 
就 不 可 能 有 研究 的 潜力 ， 没 有 自己 的 研究 ， 就 不 会 有 所 突破 ， 那 也 就 不 叫 设计 。 期 望 这 次 
经 历 能 激励 我 继续 进步 。 

在 设计 期 间 ， 感 谢 胡 XX 老师 对 我 耐心 的 指导 ， 帮 助 我 分 析 写 代码 时 犯 下 的 错误 ， 以 
及 设计 模型 等 其 他 内 容 出 现 的 问题 ， 从 而 让 我 能 更 好 地 完成 课程 设计 任务 ， 并 且 让 我 学 习 
到 更 多 的 知识 。 不 只 是 老师 ， 同 学 们 也 帮助 我 了 解 了 更 多 的 知识 ， 在 这 里 我 衷心 地 感谢 帮 
助 过 我 的 老师 和 同学 ， 谢 谢 你 们 ! 
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第 一 章 绪论 


按照 
性 ， 


存储 


1. 数据 库 的 基本 概念 


数据 库 的 四 个 基本 概念 : 数据、 数据 库 、 数 据 库 管理 系统 、 数 据 库 系统 。 

数据 : 数据 库 中 存储 的 基本 对 象 ， 是 描述 事物 的 符号 记录 。 

数据 库 : 长 期 存储 在 计算 机 内 、 有 组 织 、 可 共享 的 大 量 数据 的 集合 。 数 据 库 中 的 数据 
一 定 的 数据 模型 组 织 、 描 述 和 存储 ， 具 有 较 小 的 宛 余 度 、 较 高 的 数据 独立 性 和 易 扩展 
并 可 为 各 种 用 户 共享 。 永 久 存储 、 有 组 织 和 可 共享 是 数据 库 的 三 个 基本 特点 。 

数据 库 管理 系统 : 位 于 用 户 与 操作 系统 之 间 的 一 层 数据 管理 软件 ， 用 于 科学 地 组 织 、 
和 管理 数据 ， 高 效 地 获取 和 维护 数据 。 

数据 库 系统 : 在 计算 机 系统 中 引入 数据 库 后 的 系统 ， 一 般 由 数据 库 、 数 据 库 管 理 系统 





(及 其 开发 工具 )、 应 用 系统 、 数 据 库 管理 员 构成 。 


拟 


2. 数据 处 理 和 数据 管理 


数据 处 理 : 指 对 各 种 数据 进行 收集 、 存 储 和 加 工 和 传播 的 一 系列 活动 的 总 和 。 
数据 管理 ， 指 对 数据 进行 分 类 、 组 织 、 编 码 、 存 储 、 检 索 和 维护 。 


3. 数据 管理 技术 发 展 阶段 
数据 管理 技术 经 历 了 人 工 管理 、 文 件 系 统 和 数据 库 系 统 三 个 阶段 。 
4. 数据 独立 性 


物理 独立 性 : 指 用 户 的 应 用 程序 与 数据 库 中 数据 的 物理 存储 是 相互 独立 的 。 

逻辑 独立 性 ， 指 用 户 的 应 用 程序 与 数据 库 的 逻辑 结构 是 相互 独立 的 。 

5. 数据 模型 

数据 模型 用 来 抽象 表示 和 处 理 现实 世界 中 的 数据 和 信息 的 工具 ， 是 对 现实 世界 的 模 
是 数据 库 系统 的 核心 和 基础 ， 其 组 成 元 素 有 数据 结构 、 数 据 操作 和 完整 性 约束 。 
数据 模型 分 为 概念 模型 、 逻 辑 模型 、 物 理 模 型 。 

概念 模型 : 也 称 信息 模型 ， 按 照 用 户 的 观点 来 对 数据 和 信息 建 模 ， 主 要 用 于 数据 库 





设计 。 
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逻辑 模型 ; 按照 计算 机 系统 的 观点 对 数据 建 模 ， 用 于 DBMS 实现 。 
物理 模型 : 是 对 数据 最 底层 的 抽象 ， 描 述 数据 在 系统 内 部 的 表示 方式 和 存 取 方 法 ， 在 
磁盘 或 磁带 上 的 存储 方式 和 存 取 方法 ， 是 面向 计算 机 系统 的 。 


6. 信息 世界 中 的 基本 概念 


实体 : 客观 存在 并 可 相互 区 别 的 事物 。 
属性 : 实体 所 具有 的 某 一 特征 。 

码 : 唯一 标识 实体 的 属性 集 。 

域 : 一 组 具有 相同 数据 类 型 的 值 的 集合 。 

实体 型 ， 具 有 相同 属性 的 实体 必然 具有 的 共同 的 特征 和 性 质 。 

实体 集 : 同一 类 型 实体 的 集合 称 为 实体 集 。 

联系 : 事物 内 部 以 及 事物 之 间 是 有 联系 的 。 实 体内 部 的 联系 通常 是 指 组 成 实体 的 各 属 
性 之 间 的 联系 ， 实 体 之 间 的 联系 通常 是 指 不 同 实体 集 之 间 的 联系 。 实 体 之 间 的 联系 有 一 对 
一 、 一 对 多 和 多 对 多 等 类 型 。 

7. 常用 的 数据 模型 


层次 模型 ， 层 次 模型 是 数据 库 系 统 中 最 早出 现 的 数据 模型 ， 它 采用 树 状 结构 来 表示 各 
类 实体 及 实体 间 的 联系 。 在 数据 库 中 ， 定 义 满足 以 下 两 个 条 件 的 基本 层次 联系 的 集合 为 层 
次 模型 ， 有 且 只 有 一 个 结 点 ， 没 有 双亲 结 点 ( 根 结 点 ); 根 以 外 的 其 他 结 点 有 且 只 有 一 个 双 
灯 结 点 。 

网 状 模型 :在 数据 库 中 ， 把 满足 以 下 两 个 条 件 的 基本 层次 联系 集合 称 为 网 状 模型 ， 允 
许 一 个 以 上 的 结 点 没有 双亲 结 点 ;一 个 结 点 可 以 有 多 余 一 个 的 双亲 结 点 。 层 次 模型 实际 上 
是 网 状 模型 的 一 个 特例 ， 网 状 模型 是 比 层次 模型 更 具 普遍 性 的 结构 ， 可 以 更 直接 地 去 描述 
现实 世界 。 

关系 模型 关系 模型 是 建立 在 严格 的 数学 概念 的 基础 上 的 。 从 用 户 观 点 看 ， 关 系 模型 
由 一 组 关系 组 成 ， 每 个 关系 的 数据 结构 是 一 张 规范 化 的 二 维 表 。 关 系数 据 库 系统 采用 关系 
模型 作为 数据 的 组 织 方式 。 

8. 数据 模型 组 成 要 素 


数据 结构 : 关系 (二 维 表 )。 

数据 操作 : 主要 包括 查询 、 插 入 、 删 除 和 更 新 数据 。 这 些 操 作 必 须 满足 关系 完整 性 约 
束 条 件 。 

完整 性 约束 包括 三 大 类 : 实体 完整 性 、 参 照 完 整 性 和 用 户 定义 的 完整 性 。 

e 实体 完整 性 ， 用 于 标识 实体 的 唯一 性 。 检 查 主 码 的 值 是 否 唯一 ， 检 查 主 码 的 各 个 
属性 是 否 为 空 ， 也 不 可 取 重 复 值 。 实 体 完 整 性 在 创建 表 时 用 PRIMARY KEY 短语 

来 定义 。 
e 参照 完整 性 : 用 于 维护 实体 之 间 的 引用 关系 。 增 删改 时 检查 外 码 约束 ， 即 外 码 值 

必须 是 主 码 中 已 存在 的 值 。 在 创建 表 时 用 FOREIGN KEY 短语 定义 。 
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e@ 用户 定义 完整 性 : 针对 某 一 具体 应 用 定义 属性 上 的 约束 条 件 ， 即 属性 值 限制 。 包 
括 列 值 非 空 NOTNULL)、 列 值 唯一 (UNIQUE)、 检 查 列 值 是 否 满足 一 个 条 件 表达 
式 (CHECK 短语 ) 三 种 情况 。 


9. 数据 库 系统 的 模式 


型 : 是 指 对 某 一 类 数据 的 结构 和 属性 的 说 明 ， 对 结构 的 描述 和 说 明 。 

值 : 是 型 的 一 个 具体 赋值 ， 是 型 的 实例 。 

数据 库 模式 : 是 对 数据 库 中 全 体 数 据 的 逻辑 结构 (数据 项 的 名 字 、 类 型 、 取 值 范围 等 ) 
和 特征 (数据 之 间 的 联系 以 及 数据 有 关 的 安全 性 、 完 整 性 要 求 ) 的 描述 。 模 式 的 一 个 具体 值 
称 为 模式 的 一 个 实例 。 模 式 反 映 的 是 数据 的 结构 及 其 联系 ， 而 实例 反映 的 是 数据 库 某 一 时 
刻 的 状态 。 

10. 数据 库 的 三 级 模式 结构 (内 部 结构 ， 从 开发 人 员 角 度 ) 

(1) 模式 (逻辑 模式 ): 是 数据 库 中 全 体 数据 的 逻辑 结构 和 特征 的 描述 , 是 所 有 用 户 的 公 
共 数 据 视图 ， 一 个 数据 库 只 有 一 个 模式 。 

模式 的 地 位 : 是 数据 库 系 统 模式 结构 的 中 间 层 ， 与 数据 的 物理 存储 细节 和 硬件 环境 无 
关 ， 与 具体 的 应 用 程序 、 开 发 工具 及 高 级 程序 设计 语言 无 关 。 

模式 定义 的 内 容 : 数据 的 逻辑 结构 (数据 项 的 名 字 、 类 型 、 取 值 范围 等 )， 数 据 之 间 的 
联系 ， 数 据 有 关 的 安全 性 、 完 整 性 要 求 。 

(2) 外 模式 ( 子 模式 /用 户 模式 ): 是 数据 库 用 户 能 够 看 见 和 使 用 的 局 部 数据 的 逻辑 结构 
和 特征 的 描述 ， 是 数据 库 用 户 的 数据 视图 ， 是 与 某 一 应 用 有 关 的 系统 的 逻辑 表示 。 

外 模式 的 地 位 ， 介 于 模式 与 应 用 之 间 。 

模式 与 外 模式 的 关系 : 一 对 多 。 外 模式 通常 是 模式 的 子 集 ， 一 个 数据 库 可 以 有 多 个 外 
模式 ， 反 映 了 不 同 的 用 户 的 应 用 需求 、 看 待 数据 的 方式 、 对 数据 保密 的 要 求 。 对 模式 中 同 
一 数据 ， 在 外 模式 中 的 结构 、 类 型 、 长 度 、 保 密级 别 等 都 可 以 不 同 。 

外 模式 与 应 用 的 关系 : 一 对 多 。 同 一 外 模式 也 可 以 为 某 一 用 户 的 多 个 应 用 系统 所 使 用 。 
但 一 个 应 用 程序 只 能 使 用 一 个 外 模式 。 

(3) 内 模式 (存储 模式 ): 是 数据 物理 结构 和 存储 方式 的 描述 ,是 数据 在 数据 库 内 部 的 组 
织 方 式 。 一 个 数据 库 只 有 一 个 内 模式 。 

(4) 三 级 模式 的 优点 

e 保证 数据 的 独立 性 (内 模式 与 模式 分 开 ， 物 理 独 立 ， 外 模式 与 模式 分 开 ， 风 辑 独立 )。 

e 简化 用 户 窗口 ， 有 利于 数据 共享 ， 还 利于 数据 的 安全 保密 。 

e 数据 存储 由 DBMS 管理 (用 户 不 用 考虑 存 取 路 径 等 细节 )。 


11. 数据 库 的 二 级 映像 功能 与 数据 独立 


数据 库 的 二 级 映像 ， 外 模式 /模式 映像 、 模 式 /内 模式 映像 。 
(1) 外 模式 /模式 映像 (应 用 可 扩充 性 ) 
定义 外 模式 (局 部 逻辑 结构 ) 与 模式 (全 局 逻辑 结构 ) 之 间 的 对 应 关系 , 映像 定义 通常 包含 
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在 各 自 外 模式 的 描述 中 。 对 于 每 一 个 外 模式 ， 数 据 库 系 统 都 有 一 个 外 模式 /模式 映像 。 

用 途 : 保证 数据 的 逻辑 独立 性 。 

当 模 式 改变 时 ,数据 库 管 理 员 修改 有 关 的 外 模式 /模式 映像 ， 使 外 模式 保持 不 变 。 应 用 
程序 是 依据 数据 的 外 模式 编写 的 ， 从 而 应 用 程序 不 必修 改 ， 保 证 了 数据 与 程序 的 逻辑 独立 
性 ， 简 称 数据 的 逻辑 独立 性 。 

(2) 模式 /内 模式 映像 (空间 利用 率 ， 存 取 效 率 ) 

模式 /内 模式 映像 是 唯一 的 ， 它 定义 了 数据 全 局 逻辑 结构 与 存储 结构 之 间 的 对 应 关系 。 
该 映像 定义 通常 包含 在 模式 描述 中 。 

用 途 : 保证 数据 的 物理 独立 性 。 

如 果 数 据 库 的 存储 结构 改变 了 (例如 : 选用 了 另 一 种 存储 结构 )， 数 据 库 管 理 员 修改 模 
式 /内 模式 映像 ， 使 模式 保持 不 变 ， 应 用 程序 不 受 影响 ， 保 证 了 数据 与 程序 的 物理 独立 性 ， 
简称 数据 的 物理 独立 性 。 

(3) 二 级 映像 的 优点 

e 保证 了 数据 库 外 模式 的 稳定 性 。 

e 从 底层 保证 了 应 用 程序 的 稳定 性 ， 除 非 应 用 需求 本 身 发 生变 化 ， 否 则 应 用 程序 一 

般 不 需要 修改 。 
e 数据 与 程序 之 间 的 独立 性 ， 使 得 数据 的 定义 和 描述 可 以 从 应 用 程序 中 分 离 出 去 。 





kk 
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第 二 章 关系 数据 库 


1. 关系 模型 

关系 数据 结构 、 关 系 操作 集合 、 关 系 完整 性 约束 三 部 分 组 成 。 

2. 关系 及 其 概念 

域 : 一 组 具有 相同 数据 类 型 的 值 的 集合 。 

关系 : 笛 卡 尔 积 的 有 限 子 集 。 

候选 码 ; 关系 中 某 一 属性 组 的 值 能 唯一 地 标识 一 个 元 组 ， 而 其 子 集 不 能 。 

主 码 ， 若 一 个 关系 有 多 个 候选 码 ， 则 可 选 其 一 作为 主 码 。 

全 码 : 关系 模式 的 所 有 属性 都 是 候选 码 。 

外 码 : 如 果 一 个 关系 的 一 个 或 一 组 属性 引用 (参照 ) 了 另 一 个 关系 的 主 码 ， 则 称 这 个 或 
这 组 属性 为 外 码 。 

主 属性 : 候选 码 的 诸 属 性 称 为 主 属性 。 

非 主 属性 : 不 包含 在 任何 候选 码 中 的 属性 称 为 非 主 属性 。 

3. 关系 的 类 型 ( 表 的 类 型 ) 

基本 表 ( 基 本 关系 、 基 表 ): 实际 存在 的 表 ， 是 实际 存储 数据 的 逻辑 表示 。 

查询 表 : 查询 结果 对 应 的 表 。 

视图 表 : 由 基本 表 或 其 他 视图 表 导 出 的 表 ， 是 虚 表 ， 不 对 应 实际 存储 的 数据 。 

4. 关系 的 性 质 


列 是 同 质 的 ， 不同 的 列 可 以 出 自 相同 的 域 ， 列 的 顺序 无 所 谓 ， 行 的 顺序 无 所 谓 ， 任意 
两 个 元 组 的 候选 码 不 能 相同 ， 分 量 必须 是 原子 的 。 

5. 关系 模式 

简单 地 说 ， 关 系 模式 就 是 对 关系 的 型 的 定义 ， 包 括 关 系 的 属性 构成 、 各 属性 的 数据 类 
型 、 属 性 间 的 依赖 、 元 组 语义 及 完整 性 约束 等 。 

关系 模式 是 型 ， 是 静态 的 、 稳 定 的 。 关 系 是 关系 模式 在 某 一 时 刻 的 状态 或 内 容 ， 是 值 ， 
是 动态 的 、 随 时 间 不 断 变化 的 ， 因 为 关系 操作 在 不 断 地 更 新 着 数据 库 中 的 数据 。 

关系 模式 可 以 形式 化 地 表示 为 RIU.D.DOMLF)。 

6. 关系 数据 库 

依照 关系 模型 建立 的 数据 库 称 为 关系 数据 库 。 它 是 在 某 个 应 用 领域 的 所 有 关系 的 集合 。 

关系 数据 库 也 有 型 和 值 之 分 。 关 系数 据 库 的 型 也 称 关系 数据 库 模 式 ， 是 对 关系 数据 库 
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的 描述 。 关 系数 据 库 的 值 是 这 些 关 系 模式 在 某 一 时 刻 对 应 的 关系 的 集合 ， 通 常 称 为 关系 数 
据 库 。 


7. 关系 的 完整 性 约束 


完整 性 约束 包括 以 下 三 类 。 
e 实体 完整 性 : 若 属性 ( 指 一 个 或 一 组 属性 )A 是 基本 关系 RR 的 主 属性 , A 不 能 取 空 值 。 
检查 主 码 的 各 个 属性 不 能 为 空 且 唯一 ， 在 创建 表 时 用 PRIMARY KEY 短语 定义 。 
e 参照 完整 性 : 若 属 性 (或 属性 组 )E 是 基本 关系 及 的 外 码 ， 它 与 基本 关系 $S 的 主 码 K 
相对 应 (基本 关系 R 和 S 不 一 定 是 不 同 的 关系 )， 则 对 于 R 中 每 个 元 组 在 F 上 的 值 
必须 为 : 或 者 取 空 值 (F 的 每 个 属性 值 均 为 空 值 ); 或 者 等 于 S 中 某 个 元 组 的 主 码 值 。 
检查 增 、 删 、 改 时 的 外 码 约束 ， 在 创建 表 时 用 FOREIGN KEY 短语 定义 。 
e 用 户 定义 的 完整 性 ， 应 用 领域 需要 遵循 的 约束 条 件 ， 体 现 具体 领域 中 的 语义 约束 。 
包括 列 值 非 空 NOT NULL)、 列 值 唯 一 (UNIQUE)、 检 查 列 值 是 否 满足 一 个 条 件 表 
达 式 (CHECK 短语 ) 三 种 情况 。 
实体 完整 性 和 参照 完整 性 是 关系 模型 必须 满足 的 完整 性 约束 条 件 ， 称 为 关系 的 两 个 不 
变性 ， 应 该 由 关系 系统 自动 支持 。 
8. 关系 操作 
常用 的 关系 操作 包括 查询 、 插 和 入、 删除、 修改， 查询 是 最 主要 的 操作 。 
查询 操作 可 分 为 选择 、 投 影 、 连 接 、 除 、 并 、 差 、 交 、 笛 卡尔 积 ， 基 本 操作 是 选择 、 
投影 、 并 、 差 、 笛 卡尔 积 。 
关系 操作 的 特点 : 集合 操作 方式 ， 即 操作 的 对 象 和 结果 是 集合 。 
关系 代数 : 用 对 关系 的 运算 来 表达 查询 。 
关系 代数 运算 的 三 个 要 素 : 运算 对 象 一 关系， 运算 结果 关系 ， 运 算 符 一 一 传统 
的 集合 运算 符 ( 并 、 差 、 交 、 第 卡尔 积 )、 专 门 的 关系 运算 符 (选择 、 投 影 、 连 接 、 除 )。 
e 并 (RUS): 仍 为 n 目 关系 ， 由 属于 RR 或 属于 S 的 元 组 组 成 。 
e。 差 R-S): 仍 为 n 目 关 系 ， 由 属于 及 而 不 属于 S 的 所 有 元 组 组 成 。 
e 交 人 RnS): 仍 为 na 目 关系 ， 由 既 属 于 及 又 属于 S 的 元 组 组 成 。 
e 和 卡尔 积 : Ra 目 关系 ， ki 个 元 组 )， S(m 目 关系 ，]e 个 元 组 )， RxS(m+n 目 关系 ，k1xk 
个 元 组 )。 
e 选择 (oa ): 对 元 组 按照 条 件 进行 筛选 ， 在 关系 及 中 选择 满足 给 定 条 件 的 元 组 。 
orR)={ttsRAFO= 真 }。 
e 投影 ID: 从 及 中 选择 出 若干 属性 列 组 成 新 的 关系 。 投 影 操 作 主 要 是 从 列 的 角 
度 进行 运算 , 投影 之 后 不 仅 取 消 了 原 关系 中 的 某 些 列 , 而 且 还 可 能 取消 某 些 元 
组 (避免 重复 行 )。 


























TT:(R)= {tlAllteR} 


附录 A 章节 知识 点 。175 。 


e 连接 (9 ): 两 张 表 中 的 元 组 间 有 条 件 的 串 接 。 从 两 个 关系 的 笛 卡 尔 积 中 选取 属性 间 满 足 
一 定 条 件 的 元 组 ， 有 等 值 连接 、 自 然 连接 、 外 连接 ( 左 外 、 右 外 、 全 外) 之 分 。 

e 除 (二 ): 给 定 关系 RCXY) 和 SCYZ)， 其 中 X，Y，Z 为 属性 组 。R 中 的 立 与 S 中 的 YY 
可 以 有 不 同 的 属性 名 , 但 必须 出 自 相 同 的 域 集 。R 与 S 的 除 运算 得 到 一 个 新 的 关系 P(X)， 
了 是 及 中 满足 下 列 条 件 的 元 组 在 X 属性 列 上 的 投影 : 元 组 在 X 上 分 量 值 x 的 象 集 Y. 包 
含 S 在 Y 上 投影 的 集合 。 
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第 三 章 关系 数据 库 标 准 语言 SQL 


1. 结构 化 查询 语言 SQL 














关系 数据 库 标准 语言 SQL 是 一 种 通用 的 、 功 能 极 强 的 关系 数据 库 语言 ,是 关系 数据 存 
取 的 标准 接口 ， 也 是 不 同 数据 库 系统 之 间 相互 操作 的 基础 ， 集 数据 查询 、 数 据 操作 、 数 据 
定义 和 数据 控制 功能 于 一 体 。 
2. SQL 数据 定义 语句 
SQL 数据 定义 包括 模式 定义 、 表 定义 、 视 图 定义 和 索引 定义 。 
操作 对 象 操作 方式 
| 
模式 DROP SCHEMA 


表 CREATE TABLE DROP TABLE ALTER TABLE 
视图 CREATE VIEW DROP VIEW 


索引 CREATE INDEX DROP INDEX ALIER INDEX 


【 注 】SQL(Oracle 除外 ) 一 般 不 提供 修改 视图 定义 和 索引 定义 的 操作 ， 需 要 先 删除 再 重 





修改 





3. 基本 表 的 定义 、 修 改 、 删 除 
(1) 定义 基本 表 
CREATE TABLE < 表 名 > 

(< 列 名 > < 数据 类 型 >[ < 列 级 完整 性 约束 条 件 > ] 
[< 列 名 > < 数据 类 型 >[ < 列 级 完整 性 约束 条 件 >] ] … 
[< 表 级 完整 性 约束 条 件 > ] ); 

列 级 完整 性 约束 一 一 涉及 该 表 的 一 个 属性 。 

@ PRIMARY KEY: 主 码 约束 ; 

e NOT NULL: 非 空 值 约束 ; 

e ”UNIQUE: 唯一 性 ( 单 值 约束 ) 约 束 ; 

e “DEFAULT < 默认 值 >: 默认 ( 缺 省 ) 约 束 ; 

e CHECK<( 逻 辑 表达 式 ) >: 核查 约束 ， 定 义 校 验 条 件 。 

表 级 完整 性 约束 一 一 涉及 该 表 的 一 个 或 多 个 属性 。 

e ”UNIQUE( 属 性 列 列表 ): 限定 各 列 取 值 唯一 ; 

。 ”PRIMARY KEY( 属 性 列 列表 ): 指定 主 码 ; 

e  ” FOREIGN KEY( 属 性 列 列表 ): 
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e@ 。 REFERENCES < 表 名 > [( 属 性 列 列表 )]; 
e CHECK(< 罗 辑 表达 式 >): 检查 约束 。 
(2) 修改 基本 表 
ALTER TABLE < 表 名 > 
[ADD < 新 列 名 > < 数据 类 型 > [ 完整 性 约束 ]] 
[DROP < 列 名 > [CASCADEIRESTRICT]] 
[ADD < 表 级 完整 性 约束 >] 
[DROP CONSTRAINT < 完整 性 约束 名 > [CASCADEIRESTRICT]] 
[ALTER COLUMN < 列 名 > < 数据 类 型 > ]; 
(3) 删除 基本 表 
DROP TABLE < 表 名 > [RESTRICT| CASCADE]; 
RESTRICT: ( 受 限 ) 欲 删除 的 基本 表 不 能 被 其 他 表 的 约束 所 引用 ,如 果 存 在 依赖 该 表 的 
对 象 (触发 器 、 视 图 等 )， 则 此 表 不 能 被 删除 。 
CASCADE: (级 联 ) 在 删除 基本 表 的 同时 ， 相 关 的 依赖 对 象 一 起 删除 。 
基本 表 定 义 被 删除 , 数据 被 删除 , 表 上 建立 的 索引 、 视图、 触发 器 等 一 般 也 将 被 删除 。 
4. 数据 查询 (重点 ) 
(1) 查询 语句 的 基本 格式 
SELECT [ALLIDISTINCT] < 目标 列表 达 式 >[ 别 名 ] [< 目标 列表 达 式 > [别名 ]] … 
FROM < 表 名 或 视图 名 >[ 别 名 ][,< 表 名 或 视图 名 >[ 别 名 ]] …|(<SELECT 语句 >)[AS]< 别 名 > 
[WHERE < 条 件 表达 式 >] 
[GROUP BY < 列 名 1>[HAVING< 条 件 表达 式 >]] 
[ORDER BY < 列 名 2> [ASCIDESC]]; 
整个 SELECT 语句 的 含义 是 : 根据 WHERE 子 句 的 条 件 表达 式 从 FROM 子 句 指定 的 
基本 表 、 视 图 或 派生 表 中 找 出 满足 条 件 的 元 组 ， 再 按 SELECT 子 句 中 的 目标 列表 达 式 选 出 
元 组 中 的 属性 值 形 成 结果 表 。 
如 果 有 GROUP BY 子 句 , 则 将 结果 按照 < 列 名 1> 的 值 进行 分 组 , 值 相等 的 元 组 为 一 组 。 
如 果 GROUP BY 子 句 带 HAVING 短语 ， 则 只 有 满足 指定 条 件 的 组 才 会 输出 。 
如 果 有 ORDER BY 子 句 ， 则 结果 还 要 按照 < 列 名 2> 的 值 的 升序 或 降序 排序 。 
(2) 单 表 查 询 
Q@ 选择 表 中 的 若干 列 (投影 ) 
查询 指定 列 : (相当 于 IIA(R),A= Al,As..…,An)。 
查询 全 部 列 : 在 SELECT 关键 字 后 面 列 出 所 有 列 名 ， 按 用 户 指 定 顺 序 显示 。 或 将 < 目 
标 列表 达 式 > 指定 为 * 按 关系 模式 中 的 属性 顺序 显示 。 
查询 经 过 计算 的 值 : SELECT 子 句 的 < 目标 列表 达 式 > 中 可 以 是 表达 式 。 
@ 选择 表 中 的 若干 元 组 (选择 ) 
消除 重复 性 : 指定 DISTINCT 关键 词 ， 去 掉 表 中 重复 的 行 。 


"178 。 数据 库 系统 原理 及 应 用 课程 设计 与 实验 指导 


查询 满足 条 件 的 元 组 (通过 WHERE 子 句 实现 )，WHERE 子 句 常用 的 查询 条 件 ( 相 当 于 
cp) 如 下 。 

. 比较 大 小 : =, >, >=, <, 二 , (=, 一, !>, !<。 

。 ”确定 范围 : BETWEEN …AND…,， NOT BETWEEN…AND…。 

。 ”确定 集合 : IN < 值 表 >， NOT IN < 值 表 >。 

e ”字符 匹配 ， [NOT] LIKE,“< 匹 配 串 >”,[ESCAPE “ < 换 码 字符 >”]。 

e 涉及 空 值 的 查询 : IS NUILL 或 IS NOT NULL， 其 中 的 IS 不 能 用 = 代替 。 

e 多 重 条 件 查询 : AND 或 OR 来 联结 多 个 查询 条 件 ，AND 的 优先 级 高 于 OR， 可 以 用 括 

号 改变 优先 级 ， 可 用 来 实现 多 种 其 他 谓词 。 

@ ORDER BY 子 句 : 对 查询 结果 排序 。 

可 以 按 一 个 或 多 个 属性 列 排序 : 升序 为 ASC; 降序 为 DESC; 缺 省 值 为 升序 。 

当 排 序列 含 空 值 时 ， 空 值 最 大 ， ASC 时 排序 列 为 空 值 的 元 组 最 后 显示 ; DESC 时 排序 
列 为 空 值 的 元 组 最 先 显示 。 

@ 聚集 函数 : 对 查询 结果 集中 的 某 列 进行 计算 或 统计 。 

计数 COUNT([DISTINCTIALL] *) COUNT([DISTINCTIALL] < 列 名 >) 

计算 总 和 SUM([DISTINCTIALL] < 列 名 >) 

计算 平均 值 AVG(DISTINCTIALL] < 列 名 >) 

最 大 最 小 值 MAX([DISTINCTIALL] < 列 名 >) MIN([DISTINCTIALL] < 列 名 >) 

【 注 】 除 COUNT(9) 外 都 要 跳 过 空 值 ，WHERE 子 句 不 能 使 用 聚集 函数 。 

@ GROUPBY 子 句 : 对 查询 结果 分 组 。 

用 途 : 细 化 聚集 函数 的 作用 对 象 。 

未 对 查询 结果 分 组 ， 聚 集 函 数 将 作用 于 整个 查询 结果 ; 对 查询 结果 分 组 后 ， 聚 集 函 数 
将 分 别 作用 于 每 个 组 。 

使 用 GROUP BY 后 ， 其 SELECT 子 句 的 列 名 列表 中 只 能 出 现 分 组 属性 和 聚集 函数 。 

如 果 分 组 后 还 要 按照 条 件 对 这 些 组 进行 筛选 ， 可 使 用 HAVING 短语 指定 筛选 条 件 。 

HAVING 短语 与 WHERE 子 句 的 区 别 : 作用 对 象 不 同 。WHERE 子 句 作用 于 基本 表 或 
视图 ， 从 中 选择 满足 条 件 的 元 组 ， HAVING 短语 作用 于 组 ， 从 中 选择 满足 条 件 的 组 。 

(3) 多 表 连 接 查 询 

多 表 连 接 查 询 同 时 涉及 两 个 以 上 的 表 ， 包 括 等 值 连接 查询 、 自 然 连 接 查询 、 非 等 值 连 
接 查 询 、 自 身 连 接 查询 、 外 连接 查询 和 复合 条 件 连 接 查询 。 

(4) 霸 套 查询 

在 SQL 语言 中 ， 一 个 SELECTFROM-WHERE 语句 称 为 一 个 查询 块 。 如 将 一 个 查询 
块 嵌 套 在 另 一 个 查询 块 的 WHERE 子 句 或 HAVING 短语 的 条 件 中 , 则 此 查询 称 为 嵌 套 查询 。 
上 层 的 查询 称 为 外 查询 或 父 查询 ， 下 层 的 查询 称 为 内 查询 或 子 查询 。 

SQL 语言 还 允许 多 层 嵌 套 查询 ， 即 子 查询 中 还 可 以 嵌 套 其 他 子 查询 。 

【 注 】 子 查询 的 SELECT 子 句 中 不 能 使 用 ORDER BY 子 句 。 
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Q@ IN 谓词 子 查询 
在 嵌 套 查询 中 ， 子 查询 的 结果 常常 是 一 个 集合 。 故 谓词 IN 经 常用 于 嵌 套 查询 ， 其 一 
般 格式 如 下 。 
SELECT < 目标 列表 达 式 列表 > 
FROM 表 名 
WHERE 列 名 IN 
(SELECT 子 句 ) 
@ 比较 运算 符 的 子 查询 
比较 运算 符 的 子 查询 是 指 父 查询 与 子 查 询 之 间 通 过 比较 运算 符 进 行 连接 的 嵌 套 查询 。 
当 能 确切 知道 子 查询 返回 的 是 单个 值 时 , 父 查询 与 子 查询 之 间 可 以 通过 比较 运算 符 (>、 盖 、 
<、<=、=、!=) 连 接 起 来 。 
@ EXISTS 谓词 子 查 询 
带 EXISTS 谓词 的 子 查询 不 返回 任何 数据 ,只 产生 逻辑 真 值 TRUE 或 逻辑 假 值 FALSE。 
若 内 层 查询 结果 非 空 ， 则 外 层 的 WHERE 子 句 返回 真 值 ， 否 则 返回 假 值 。 
由 EXISTS 引出 的 子 查询 ， 其 目标 列表 达 式 通常 都 用 * ， 因 为 带 EXISTS 的 子 查 询 只 
返回 真 值 或 假 值 ， 给 出 列 名 无 实际 意义 。 
EXISTS 子 查询 中 一 般 是 相关 子 查询 ， 即 子 查 询 脱 离 父 查询 后 不 能 单独 执行 。 
@ 不 相关 子 查询 与 相关 子 查询 
如 果子 查询 的 查询 条 件 不 依赖 于 父 查 询 ， 称 为 不 相关 子 查询 ; 依赖 于 父 查询 ， 称 为 相关 
子 查 询 。 不 相关 子 查询 常用 的 求解 方法 是 由 里 向 外 处 理 ， 即 先 执行 子 查询 ， 子 查询 的 结果 用 
于 建立 父 查 询 的 查询 条 件 。 相 关子 查询 的 求解 与 不 相关 子 查询 的 求解 完全 不 同 ， 不 能 一 次 将 
子 查询 求解 出 来 ,然后 求解 父 查询 , 由 于 子 查询 与 父 查询 相关 , 因此 必须 对 子 查询 反复 求 值 。 
(5) 集合 查询 
SELECT 语句 的 查询 结果 是 元 组 的 集合 ,因此 多 个 SELECT 语句 的 查询 结果 可 进行 集 
合 操作 。 参 加 集合 操作 的 各 查询 结果 的 列 数 必须 相同 ， 对 应 项 的 数据 类 型 也 必须 相同 。 
常见 的 集合 操作 包括 并 操作 UNION、 交 操作 INTERSECT 和 差 操 作 EXCEPT。 
5. 数据 更 新 (增删 改 ) 
(1) 插入 数据 
@ 插入 元 组 


INSERT [INTO] < 表 名 > [(< 属 性 列 1>[< 属 性 列 2 >.….)] 
VALUES (< 常量 1> [< 常量 2>] 。… ) 


功能 : 将 新 元 组 插入 指定 表 中 ;新 元 组 的 属性 列 1 的 值 为 常量 1， 属 性 列 2 的 值 为 常 








e INTO 子 句 : 属性 列 的 顺序 可 与 表 定 义 中 的 顺序 不 一 致 ， 但 须 指定 列 名 ; 没有 指定 属性 
列 ， 表 示 要 插入 的 是 一 条 完整 的 元 组 ; 指定 部 分 属性 列 ， 未 指定 的 属性 列 取 空 值 ， 具 有 
NOT NULL 的 属性 列 除外 。 
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Q@ IN 谓词 子 查询 
在 嵌 套 查询 中 ， 子 查询 的 结果 常常 是 一 个 集合 。 故 谓词 IN 经 常用 于 嵌 套 查询 ， 其 一 
般 格式 如 下 。 
SELECT < 目标 列表 达 式 列表 > 
FROM 表 名 
WHERE 列 名 IN 
(SELECT 子 句 ) 
@ 比较 运算 符 的 子 查询 
比较 运算 符 的 子 查询 是 指 父 查询 与 子 查 询 之 间 通 过 比较 运算 符 进 行 连接 的 嵌 套 查询 。 
当 能 确切 知道 子 查询 返回 的 是 单个 值 时 , 父 查询 与 子 查询 之 间 可 以 通过 比较 运算 符 (>、 盖 、 
<、<=、=、!=) 连 接 起 来 。 
@ EXISTS 谓词 子 查 询 
带 EXISTS 谓词 的 子 查询 不 返回 任何 数据 ,只 产生 逻辑 真 值 TRUE 或 逻辑 假 值 FALSE。 
若 内 层 查询 结果 非 空 ， 则 外 层 的 WHERE 子 句 返回 真 值 ， 否 则 返回 假 值 。 
由 EXISTS 引出 的 子 查询 ， 其 目标 列表 达 式 通常 都 用 * ， 因 为 带 EXISTS 的 子 查 询 只 
返回 真 值 或 假 值 ， 给 出 列 名 无 实际 意义 。 
EXISTS 子 查询 中 一 般 是 相关 子 查询 ， 即 子 查 询 脱 离 父 查询 后 不 能 单独 执行 。 
@ 不 相关 子 查询 与 相关 子 查询 
如 果子 查询 的 查询 条 件 不 依赖 于 父 查 询 ， 称 为 不 相关 子 查询 ; 依赖 于 父 查询 ， 称 为 相关 
子 查 询 。 不 相关 子 查询 常用 的 求解 方法 是 由 里 向 外 处 理 ， 即 先 执行 子 查询 ， 子 查询 的 结果 用 
于 建立 父 查 询 的 查询 条 件 。 相 关子 查询 的 求解 与 不 相关 子 查询 的 求解 完全 不 同 ， 不 能 一 次 将 
子 查询 求解 出 来 ,然后 求解 父 查询 , 由 于 子 查询 与 父 查询 相关 , 因此 必须 对 子 查询 反复 求 值 。 
(5) 集合 查询 
SELECT 语句 的 查询 结果 是 元 组 的 集合 ,因此 多 个 SELECT 语句 的 查询 结果 可 进行 集 
合 操作 。 参 加 集合 操作 的 各 查询 结果 的 列 数 必须 相同 ， 对 应 项 的 数据 类 型 也 必须 相同 。 
常见 的 集合 操作 包括 并 操作 UNION、 交 操作 INTERSECT 和 差 操 作 EXCEPT。 
5. 数据 更 新 (增删 改 ) 
(1) 插入 数据 
@ 插入 元 组 


INSERT [INTO] < 表 名 > [(< 属 性 列 1>[< 属 性 列 2 >.….)] 
VALUES (< 常量 1> [< 常量 2>] 。… ) 


功能 : 将 新 元 组 插入 指定 表 中 ;新 元 组 的 属性 列 1 的 值 为 常量 1， 属 性 列 2 的 值 为 常 








e INTO 子 句 : 属性 列 的 顺序 可 与 表 定 义 中 的 顺序 不 一 致 ， 但 须 指定 列 名 ; 没有 指定 属性 
列 ， 表 示 要 插入 的 是 一 条 完整 的 元 组 ; 指定 部 分 属性 列 ， 未 指定 的 属性 列 取 空 值 ， 具 有 
NOT NULL 的 属性 列 除外 。 
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Q@ IN 谓词 子 查询 
在 嵌 套 查询 中 ， 子 查询 的 结果 常常 是 一 个 集合 。 故 谓词 IN 经 常用 于 嵌 套 查询 ， 其 一 
般 格式 如 下 。 
SELECT < 目标 列表 达 式 列表 > 
FROM 表 名 
WHERE 列 名 IN 
(SELECT 子 句 ) 
@ 比较 运算 符 的 子 查询 
比较 运算 符 的 子 查询 是 指 父 查询 与 子 查 询 之 间 通 过 比较 运算 符 进 行 连接 的 嵌 套 查询 。 
当 能 确切 知道 子 查询 返回 的 是 单个 值 时 , 父 查询 与 子 查询 之 间 可 以 通过 比较 运算 符 (>、 盖 、 
<、<=、=、!=) 连 接 起 来 。 
@ EXISTS 谓词 子 查 询 
带 EXISTS 谓词 的 子 查询 不 返回 任何 数据 ,只 产生 逻辑 真 值 TRUE 或 逻辑 假 值 FALSE。 
若 内 层 查询 结果 非 空 ， 则 外 层 的 WHERE 子 句 返回 真 值 ， 否 则 返回 假 值 。 
由 EXISTS 引出 的 子 查询 ， 其 目标 列表 达 式 通常 都 用 * ， 因 为 带 EXISTS 的 子 查 询 只 
返回 真 值 或 假 值 ， 给 出 列 名 无 实际 意义 。 
EXISTS 子 查询 中 一 般 是 相关 子 查询 ， 即 子 查 询 脱 离 父 查询 后 不 能 单独 执行 。 
@ 不 相关 子 查询 与 相关 子 查询 
如 果子 查询 的 查询 条 件 不 依赖 于 父 查 询 ， 称 为 不 相关 子 查询 ; 依赖 于 父 查询 ， 称 为 相关 
子 查 询 。 不 相关 子 查询 常用 的 求解 方法 是 由 里 向 外 处 理 ， 即 先 执行 子 查询 ， 子 查询 的 结果 用 
于 建立 父 查 询 的 查询 条 件 。 相 关子 查询 的 求解 与 不 相关 子 查询 的 求解 完全 不 同 ， 不 能 一 次 将 
子 查询 求解 出 来 ,然后 求解 父 查询 , 由 于 子 查询 与 父 查询 相关 , 因此 必须 对 子 查询 反复 求 值 。 
(5) 集合 查询 
SELECT 语句 的 查询 结果 是 元 组 的 集合 ,因此 多 个 SELECT 语句 的 查询 结果 可 进行 集 
合 操作 。 参 加 集合 操作 的 各 查询 结果 的 列 数 必须 相同 ， 对 应 项 的 数据 类 型 也 必须 相同 。 
常见 的 集合 操作 包括 并 操作 UNION、 交 操作 INTERSECT 和 差 操 作 EXCEPT。 
5. 数据 更 新 (增删 改 ) 
(1) 插入 数据 
@ 插入 元 组 


INSERT [INTO] < 表 名 > [(< 属 性 列 1>[< 属 性 列 2 >.….)] 
VALUES (< 常量 1> [< 常量 2>] 。… ) 


功能 : 将 新 元 组 插入 指定 表 中 ;新 元 组 的 属性 列 1 的 值 为 常量 1， 属 性 列 2 的 值 为 常 








e INTO 子 句 : 属性 列 的 顺序 可 与 表 定 义 中 的 顺序 不 一 致 ， 但 须 指定 列 名 ; 没有 指定 属性 
列 ， 表 示 要 插入 的 是 一 条 完整 的 元 组 ; 指定 部 分 属性 列 ， 未 指定 的 属性 列 取 空 值 ， 具 有 
NOT NULL 的 属性 列 除外 。 
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Q@ IN 谓词 子 查询 
在 嵌 套 查询 中 ， 子 查询 的 结果 常常 是 一 个 集合 。 故 谓词 IN 经 常用 于 嵌 套 查询 ， 其 一 
般 格式 如 下 。 
SELECT < 目标 列表 达 式 列表 > 
FROM 表 名 
WHERE 列 名 IN 
(SELECT 子 句 ) 
@ 比较 运算 符 的 子 查询 
比较 运算 符 的 子 查询 是 指 父 查询 与 子 查 询 之 间 通 过 比较 运算 符 进 行 连接 的 嵌 套 查询 。 
当 能 确切 知道 子 查询 返回 的 是 单个 值 时 , 父 查询 与 子 查询 之 间 可 以 通过 比较 运算 符 (>、 盖 、 
<、<=、=、!=) 连 接 起 来 。 
@ EXISTS 谓词 子 查 询 
带 EXISTS 谓词 的 子 查询 不 返回 任何 数据 ,只 产生 逻辑 真 值 TRUE 或 逻辑 假 值 FALSE。 
若 内 层 查询 结果 非 空 ， 则 外 层 的 WHERE 子 句 返回 真 值 ， 否 则 返回 假 值 。 
由 EXISTS 引出 的 子 查询 ， 其 目标 列表 达 式 通常 都 用 * ， 因 为 带 EXISTS 的 子 查 询 只 
返回 真 值 或 假 值 ， 给 出 列 名 无 实际 意义 。 
EXISTS 子 查询 中 一 般 是 相关 子 查询 ， 即 子 查 询 脱 离 父 查询 后 不 能 单独 执行 。 
@ 不 相关 子 查询 与 相关 子 查询 
如 果子 查询 的 查询 条 件 不 依赖 于 父 查 询 ， 称 为 不 相关 子 查询 ; 依赖 于 父 查询 ， 称 为 相关 
子 查 询 。 不 相关 子 查询 常用 的 求解 方法 是 由 里 向 外 处 理 ， 即 先 执行 子 查询 ， 子 查询 的 结果 用 
于 建立 父 查 询 的 查询 条 件 。 相 关子 查询 的 求解 与 不 相关 子 查询 的 求解 完全 不 同 ， 不 能 一 次 将 
子 查询 求解 出 来 ,然后 求解 父 查询 , 由 于 子 查询 与 父 查询 相关 , 因此 必须 对 子 查询 反复 求 值 。 
(5) 集合 查询 
SELECT 语句 的 查询 结果 是 元 组 的 集合 ,因此 多 个 SELECT 语句 的 查询 结果 可 进行 集 
合 操作 。 参 加 集合 操作 的 各 查询 结果 的 列 数 必须 相同 ， 对 应 项 的 数据 类 型 也 必须 相同 。 
常见 的 集合 操作 包括 并 操作 UNION、 交 操作 INTERSECT 和 差 操 作 EXCEPT。 
5. 数据 更 新 (增删 改 ) 
(1) 插入 数据 
@ 插入 元 组 


INSERT [INTO] < 表 名 > [(< 属 性 列 1>[< 属 性 列 2 >.….)] 
VALUES (< 常量 1> [< 常量 2>] 。… ) 


功能 : 将 新 元 组 插入 指定 表 中 ;新 元 组 的 属性 列 1 的 值 为 常量 1， 属 性 列 2 的 值 为 常 








e INTO 子 句 : 属性 列 的 顺序 可 与 表 定 义 中 的 顺序 不 一 致 ， 但 须 指定 列 名 ; 没有 指定 属性 
列 ， 表 示 要 插入 的 是 一 条 完整 的 元 组 ; 指定 部 分 属性 列 ， 未 指定 的 属性 列 取 空 值 ， 具 有 
NOT NULL 的 属性 列 除外 。 
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e ”VALUES 子 句 : 提供 的 值 必须 与 INTO 子 句 匹配 ， 包 括 值 的 个 数 、 值 的 类 型 。 

@ 插入 子 查 询 结 果 

INSERT INTO < 表 名 >[(< 属 性 列 1>[;< 属 性 列 2 >…)] 

子 查询 (SELECT 等 ); 

(2) 修改 数据 

UPDATE < 表 名 > 

SET < 列 名 盖 < 表 达 式 >[,< 列 名 >=< 表 达 式 >]… 

[WHERE < 条 件 >]; 

功能 : 修改 指定 表 中 满足 WHERE 子 句 条 件 的 元 组 。 

e ”SET 子 句 : 指定 修改 方式 ， 要 修改 的 列 ， 修 改 后 取 值 : < 表达 式 >。 

。 WHERE 子 句 : 指定 要 修改 的 元 组 ， 缺 省 表示 要 修改 表 中 的 所 有 元 组 。 

(3) 删除 数据 

DELETE 

FROM < 表 名 > 

[WHERE < 条 件 >]; 

功能 :删除 指定 表 中 满足 WHERE 子 句 条 件 的 元 组 。 

WHERE 子 句 : 指定 要 删除 的 元 组 ， 缺 省 表示 要 删除 表 中 的 全 部 元 组 ， 表 的 定义 仍 在 
数据 字典 中 。 

6. 视图 


特点 : 虚 表 ， 从 一 个 或 几 个 基本 表 ( 或 视图 ) 导 出 的 表 ; 只 存放 视图 的 定义 ， 不 存放 视 
图 对 应 的 数据 ; 基本 表 中 的 数据 发 生变 化 ， 从 视图 中 查询 出 的 数据 也 随 之 改变 。 

基于 视图 的 操作 : 查询 、 删 除 、 受 限 更 新 、 定 义 基 于 该 视图 的 新 视图 。 

(1) 定义 视图 

CREATE VIEW < 视图 名 > [(< 列 名 > [< 列 名 >]…)] 

AS < 子 查 询 > 

[WITH CHECK OPTION]: 

e 子 查 询 : 不 允许 含有 ORDER BY 子 句 和 DISTINCT 短语 。 

e WITH CHECK OPTION: 表示 对 视图 进行 UPDATE、INSERT 和 DELETE 操作 时 要 保 

证 更 新 、 插 入 或 删除 的 行 满足 视图 定义 中 的 谓词 条 件 ( 即 子 查询 中 的 条 件 表达 式 )。 

e 组 成 视图 的 属性 列 名 : 全 部 省 略 或 全 部 指定 。 

在 下 列 三 种 情况 下 必须 明确 指定 组 成 视图 的 所 有 列 名 : 

。 某 个 目标 列 不 是 单纯 的 属性 名 ， 而 是 聚集 函数 或 列表 达 式 。 

e 多 表 连 接 时 选 出 了 几 个 同名 列 作为 视图 的 字段 。 

e 需要 在 视图 中 为 某 个 列 启用 新 的 名 字 。 

RDBMS 执行 CREATE VIEW 语句 时 ， 只 是 把 视图 定义 存 入 数据 字典 ， 并 不 执行 其 中 
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的 SELECT 语句 。 在 对 视图 查询 时 ， 按 视图 的 定义 从 基本 表 中 将 数据 查 出 。 

行列 子 集 视 图 : 从 单个 基本 表 导 出 ， 只 是 去 掉 了 基本 表 的 某 些 行 和 某 些 列 ， 但 保留 了 
主 码 。 

由 于 视图 中 的 数据 不 会 实际 存储 ， 所 以 定义 视图 时 可 根据 应 用 的 需要 ， 设 置 一 些 派生 
属性 列 或 虚拟 列 ， 以 便于 查询 和 统计 。 

以 SELECT* 方式 创建 的 视图 可 扩充 性 差 ， 应 尽 可 能 避免 。 

(2) 删除 视图 

DROP VIEW < 视图 名 >; 


该 语句 从 数据 字典 中 删除 指定 的 视图 定义 。 如 果 该 视图 上 还 导出 了 其 他 视图 ， 使 用 
CASCADE 级 联 删 除 语句 ， 把 该 视图 和 由 它 导出 的 所 有 视图 一 起 删除 。 删 除 基 本 表 时 ， 由 
该 基本 表 导 出 的 所 有 视图 定义 都 必须 显 式 地 使 用 DROP VIEW 语句 删除 。 

(3) 查询 视图 

查询 视图 与 查询 基本 表 相同 ， 视 图 定义 后 ， 就 可 以 像 对 待 基本 表 一 样 对 视图 进行 查询 
(SELECT) 操 作 。 查 询 视 图 采用 视图 消解 法 。 

视图 消解 法 (View Resolution) 进 行 有 效 性 检查 ,检查 查询 的 表 、 视 图 等 是 否 存 在 。 如 果 
存在 ， 则 从 数据 字典 中 取出 视图 的 定义 ， 转换 成 等 价 的 对 基本 表 的 查询 ， 把 视图 定义 中 的 
子 查 询 与 用 户 的 查询 结合 起 来 :执行 修正 后 的 查询 。 

(4) 更 新 视图 

DBMS 实现 视图 更 新 的 方法 : 转换 为 对 基本 表 的 更 新 。 方 法 为 视图 消解 法 。 只 有 对 成 
为 “可 更 新 ”视图 才能 进行 更 新 操作 。 
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第 四 章 ”数据 库 安全 


1. 计算 机 系统 的 三 类 安全 性 问题 
技术 安全 、 管 理 安全 、 政 策 法 律 。 
2. 数据 库 安全 性 控制 


(1) 用 户 标识 与 鉴别 

静态 口令 鉴别 、 动 态 口令 鉴别 、 生 物 特征 鉴别 、 智 能 卡 鉴别 。 

(2) 存 取 控制 

e 自主 存 取 控制 : 定义 各 个 用 户 对 不 同 数据 对 象 的 存 取 权 限 。 当 用 户 要 访问 数据 库 时 ， 首 
先 要 检查 其 存 取 权 限 ， 以 防止 非法 用 户 对 数据 库 进行 存 取 。“ 自 主 存 取 控制 ”中 “自主 ” 
的 含义 为 用 户 可 以 将 自己 所 拥有 的 存 取 权限 “自主 ”地 授予 他 人 , 即 用 户 具 有 一 定 的 “ 自 
主 ” 权 。 

e 强制 存 取 控制 : 每 一 个 数据 对 象 被 (强制 地 ) 标 以 一 定 的 加 密级 别 , 每 位 用 户 也 被 (强制 地 ) 
授予 某 一 级 别 的 许可 证 。 系 统 规定 只 有 具有 某 一 许可 证 级 别 的 用 户 ， 才 能 存 取 加 密级 别 
的 数据 对 象 。 强 制 存 取 控制 (MAC) 是 对 数据 本 身 进行 密级 标记 ， 无 论 数据 如 何 复制 ， 标 
记 与 数据 是 一 个 不 可 分 的 整体 ， 只 有 符合 密级 标记 要 求 的 用 户 才 可 以 操作 数据 ， 从 而 提 
高 了 更 高 级 别 的 安全 性 。 

(3) 授权 与 收回 

GRANT 语句 和 REVOKE 语句 实现 关系 数据 库 系统 中 存 取 控制 权限 。 

Q@ GRANT( 授 权 ) 

GRANT < 权限 >[L< 权 限 >].… 

ON < 对 象 类 型 > < 对 象 名 > ,[< 对 象 类 型 > < 对 象 名 >] 

TO < 用 户 >L< 用 户 >].… 

[WITH GRANT OPTION]: 

功能 : 将 对 指定 操作 对 象 的 指定 操作 权限 授予 指定 的 用 户 。 

@ REVOKE( 收 回 权限 ) 


REVOKE < 权限 >[L.< 权 限 >].… 

ON < 对 象 类 型 > < 对 象 名 > >L< 对 象 类 型 > < 对 象 名 >] … 

FROM < 用 户 >[,< 用 户 >].…. >[CASCADEIRESTRICT]: 

功能 : 把 指定 对 象 的 指定 操作 权限 从 指定 用 户 处 收回 。 
(4) 创建 数据 库 模式 的 权限 

DBA 在 创建 用 户 时 实现 。 


CREAIE USER <usemame> 
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[WITH] [DBA|RESOURCE |CONNECT] 


拥有 DBA 权限 的 用 户 是 系统 中 的 超级 用 户 ， 只 有 系统 的 超级 用 户 才 有 权 创 建新 的 数 
据 库 用 户 ; 如 果 没 有 指定 创建 的 新 用 户 的 权限 ， 默 认 该 用 户 拥 有 CONNECT 权限 ， 只 能 

(5) 数据 库 角 色 

数据 库 角色 是 被 命名 的 一 组 与 数据 库 操 作 相关 的 权限 ， 是 权限 的 集合 ， 通 过 角色 授权 
可 简化 授权 过 程 。 用 CREATE ROLE 语句 创建 角色 ， 然 后 用 GRANT 语句 给 角色 授权 。 
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第 五 章 数据 库 完整 性 


1. 数据 库 完整 性 


数据 库 的 完整 性 是 指数 据 的 正确 性 和 相 容 性 。 数 据 的 正确 性 是 指数 据 是 符合 现实 世界 
语义 、 反 映 当前 实际 状况 的 。 数 据 的 相 容 性 是 指数 据 库 同一 对 象 在 不 同 的 关系 表 中 的 数据 
是 符合 逻辑 的 。 


2. 保障 数据 库 的 完整 性 


提供 定义 完整 性 约束 条 件 的 机 制 。 
提供 完整 性 检查 的 方法 。 
进行 违约 处 理 。 


3. 数据 完整 性 约束 条 件 
前 文中 已 经 讲述 ， 此 处 不 再 次 述 。 
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第 六 章 关系 数据 理论 


1. 问题 的 提出 
针对 一 个 具体 问题 , 如 何 构 造 一 个 适合 于 它 的 数据 库 模式 , 即 应 该 构造 几 个 关系 模式 。 
2. 数据 依赖 


反映 一 个 关系 内 部 属性 与 属性 之 间 的 约束 关系 ， 是 现实 世界 属性 间 相 互联 系 的 抽象 ， 
属于 数据 内 在 的 性 质 和 语义 的 体现 。 


3. 判断 一 个 关系 模式 是 否 是 好 的 模式 的 标准 





不 会 发 生 插 入 异常 、 删 除 异常 和 更 新 异常 ， 数 据 见 余 尽 可 能 少 。 
4. 规范 化 理论 


规范 化 理论 是 用 来 设计 良好 的 关系 模式 的 基本 理论 。 它 通过 分 解 关系 模式 来 消除 其 中 
不 合适 的 数据 依赖 ， 以 解决 插入 异常 、 删 除 异常 、 更 新 异常 和 数据 元 余 问 题 。 

5. 函数 依赖 

设 RU) 是 一 个 属性 集 U 上 的 关系 模式 , X 和 立 是 U 的 子 集 ， 若 对 于 RU) 的 任意 一 个 
可 能 的 关系 r，Fr 中 不 可 能 存在 两 个 元 组 在 X 上 的 属性 值 相 等 ， 而 在 Y 上 的 属性 值 不 等 ， 
则 称 “X 函数 确定 Y” 或 “Y 函数 依赖 于 X”， 记 作 X-Y。 

简单 地 说 ， 对 于 关系 模式 的 两 个 属性 子 集 X 和 Y， 若 X 的 任 一 取 值 能 唯一 确定 Y 的 
值 ， 则 称 YY 函数 依赖 于 义 ， 记 作 义 一 Y。 

设 R(D) 是 属性 集 U 上 的 关系 模式 ，X、Y 是 U 的 子 集 : 

e 如 果 X 和 立 之 间 是 1 :1 关系 (一 对 一 关系 )， 则 存在 函数 依赖 X 一 Y 和 Y 一 X。 

e。 如果 和 和 YY 之 间 是 1 :mn 关 系 (一 对 多 关系 )， 则 存在 函数 依赖 了 一 X。 

e ”如 果 和 和 立 之 间 是 m :了 关系 (多 对 多 关系 )， 则 和 和 了 之 间 不 存在 函数 依赖 。 

注意 : 函数 依赖 不 是 指 关 系 模式 R 的 某 个 或 某 些 关 系 满足 约束 条 件 ， 而 是 指 及 的 一 切 
关系 均 要 满足 约束 条 件 。 


6. 平凡 函数 依赖 与 非 平 凡 函 数 依赖 

对 于 关系 模式 的 两 个 属性 子 集 X 和 YY， 如 果 X-~Y,， 但 YSX,， 则 称 X~Y 为 非 平 凡 函 
数 依赖 ， 如 果 X->Y， 且 YEX， 则 称 久 一 YY 为 非 平凡 函数 依赖 。 

7. 完全 函数 依赖 与 部 分 函数 依赖 

对 于 关系 模式 的 两 个 属性 子 集 X 和 站， 如 果 X-~~Y， 并 且 对 于 X 的 任何 一 个 真子 集 
X， 都 有 X-Y， 则 称 立 对 和 完全 函数 依赖 : 如 果 X-Y， 但 站 不 完全 函数 依赖 于 和 X， 则 
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称 Y 对 义 部 分 函数 依赖 。 

8. 传递 函数 依赖 

对 于 关系 模式 的 两 个 属性 子 集 义 和 Y， 如 果 XX 一 Y(YZX)，Y 十 X，Y 一 Z(Z&Y)， 则 称 
Z 对 义 传递 函数 依赖 。 


9. 码 


候选 码 : 设 为 R<U,F> 中 的 属性 或 属性 组 ， 若 K 完全 函数 决定 U( 每 个 属性 )， 则 K 
称 为 R 的 候选 码 。 

K 需要 满足 以 下 两 个 条 件 : 

(1) KK 完全 函数 决定 该 关系 的 所 有 其 他 属性 。 

(2)K 的 任何 真子 集 都 不 能 完全 函数 决定 RR 的 所 有 其 他 属性 ，K 必须 是 最 小 的 。 

若 候 选 码 多 于 一 个 ， 则 选 定 其 中 的 一 个 作为 主 码 (PRIMARY KEY)， 通 常 称 之 为 码 。 

主 属性 (PRIME ATTRIBUTE): 包含 在 任何 一 个 候选 码 中 的 属性 。 

非 主 属性 或 非 码 属性 : 不 包含 在 任何 码 中 的 属性 。 

外 码 : 关系 模式 R 中 属性 或 属性 组 X 并 非 及 的 码 ， 但 X 是 另 一 个 关系 模式 的 码 ， 则 
称 义 是 RR 的 外 部 码 ， 也 称 外 码 。 

10. 范式 

范式 指 符合 某 一 种 级 别 的 关系 模式 的 集合 。 在 设计 关系 数据 库 时 ， 根 据 满足 依赖 关系 
要 求 的 不 同 ， 定 义 为 不 同 的 范式 。 

11. 规范 化 

规范 化 指 将 一 个 低 一 级 范式 的 关系 模式 ， 通 过 模式 分 解 转换 为 若干 个 高 一 级 范式 的 关 
系 模式 的 集合 的 过 程 。 

转换 后 ， 可 以 在 一 定 程度 上 减轻 原 关 系 模式 中 存在 的 插入 异常 、 删 除 异常 、 数 据 见 余 
度 大 、 修改 复杂 等 问题 , 但 并 不 一 定 能 完全 消除 原 关 系 模式 中 的 各 种 异常 情况 和 数据 元 余 。 

12. 范式 及 关系 

范式 之 间 的 关系 : INF> 2NF2 3NF> BCNF2 4NF2 SNF。 

(1) INF: 如 果 一 个 关系 模式 R 的 所 有 属性 都 是 不 可 分 的 基本 数据 项 ， 则 RE 1NF。 

1NF 是 对 关系 模式 的 最 起 码 要 求 。 不 满足 1NF 的 数据 库 模式 不 能 称 为 关系 数据 库 ; 但 
满足 1NF 的 关系 模式 并 不 一 定 是 一 个 好 的 关系 模式 。 

(2) 2NF: 如 果 RE1lNF， 且 每 一 个 非 主 属性 完全 函数 依赖 于 码 ， 则 RE2NF。 

简 而 言 之 ， 第 二 范式 就 是 每 一 行 被 码 唯一 标识 。 

(3) 3NF: 如 果 RE2NF, 是 每 一 个 非 主 属性 都 不 传递 依赖 于 R 的 候选 码 , 则 RE3NF。 

2NF 和 3NF 都 是 对 非 主 属性 的 要 求 , 2NF 要 求 每 一 个 非 主 属性 完全 函数 依赖 于 码 , 3NF 
要 求 每 一 个 非 主 属性 既 不 部 分 函数 依赖 于 码 ， 也 不 传递 依赖 于 码 。 

局 部 依赖 和 传递 依赖 是 模式 产生 数据 匈 余 和 操作 异常 的 两 个 重要 原因 。 
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(4) BCNF: 关系 模式 R<U, F>E1NF, 若 X--Y 且 YEX 时 ,X 必 含有 码 , 则 R<U,F> E 
BCNF。 等 价 于 : 每 一 个 决定 因素 都 包含 码 ， 即 消除 任何 属性 对 码 的 部 分 和 传递 函数 依赖 。 
BCNEF 不 仅 对 非 主 属性 有 要 求 ， 而 且 也 对 主 属性 有 要 求 。 如 果 一 个 关系 模式 只 有 两 个 
属性 构成 ， 则 该 关系 模式 一 定 属于 BCNF。 
充分 


(5) 3NF 与 BCNF 的 关系 : REBCNF < 一 RE3NF。 
不 必要 


充分 


如 果 RE3NF， 且 RR 只 有 一 个 候选 码 ， Ne RE3NF。 
必要 


(6) 4NF: 如 果 REe1NF， 对 于 RR 的 每 一 个 非 平凡 多 值 依赖 X 一 一 Y(YEX)，X 都 含有 
码 ， 则 RE4NF。 

4NF 就 是 限制 关系 模式 的 属性 之 间 不 允许 有 非 平凡 且 非 函数 依赖 的 多 值 依赖 。 

(7) 规范 化 过 程 如 下 。 


INF 
| 消除 非 主 属性 对 码 的 部 分 函数 依赖 
2NF 
消除 决定 因素 
4 消除 非 主 属性 对 码 的 传递 函 数 依赖 
非 码 的 非 平凡 
3NF 
函数 依 各 站 消除 主 属性 对 码 的 部 分 和 传递 函数 依赖 
Ch EX BCNF 
消除 非 平凡 且 非 函数 依赖 的 多 值 依赖 
4NF 


13. Armstrong 公理 系统 


(1) 逻辑 蕴涵 : 对 于 满足 一 组 函数 依赖 下 的 关系 模式 R<U，F>， 其 任何 一 个 关系 T， 
若 函 数 依 赖 X 一 Y 都 成 立 ， 则 称 F 逻辑 蕴涵 X 一 Y。 

(2) Armstrong 公理 系统 : 自 反 律 、 增 广 律 、 传 递 律 。 

e@ 自 反 律 : 若 YcXcU， 则 XY 为 F 所 蕴涵 。 

。 增 广 律 : 若 X~~Y 为 了 所 蕴涵 ， 且 ZcU， 则 XZ-~YZ 为 了 所 蕴涵 。 

e ”传递 律 : 车 XX 一 Y 及 Y 一 Z 为 F 所 蕴涵 ， 则 XX 一 Z 为 了 所 蕴涵 。 

(3) 三 条 有 用 的 推理 规则 : 合并 规则 、 伪 传递 规则 、 分 解 规则 。 

e@ ”合并 规则 由 XY,，X 一 Z， 有 X 一 YZ。 

e ” 伪 传 递 规则 由 XY,， WY 一 Z， 有 XW 一 Z。 

。 分解 规则 由 XY 及 ZcY， 有 X 一 Z。 

(4) Armstrong 公理 系统 的 有 效 性 和 完备 性 。 

有 效 性 : 由 下 出 发 ， 根 据 Armstrong 公理 推导 出 来 的 每 一 个 函数 依赖 一 定 在 FF 中 。 

完备 性 : F 中 的 每 一 个 函数 依赖 ， 必 定 可 以 由 F 出 发 根据 Ammstrong 公理 推导 出 来 。 
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(5) 函数 依赖 半 包 下 与 属性 集 闭 包 XE'。 

函数 依赖 闭 包 F*: 在 关系 模式 R<U.F> 中 为 F 所 人 逻辑 蕴涵 的 函数 依赖 的 全 体 。F 的 求 
解 是 NP 完全 问题 。 
属性 集 闭 包 Xe*: 设 F 为 属性 集 U 上 的 一 组 函数 依赖 ，XcU, Xr'={AIX->A 能 
据 Armstrong 公理 导出 }，Xs' 称 为 属性 集 义 关于 函数 依赖 集 F 的 闭 包 。 
属性 集 闭 包 X#' 两 个 重要 的 应 用 : 判断 函数 依赖 X 一 Y 是 否 为 F 所 人 逻辑 蕴涵 ( 即 判断 Y 
是 否 属于 Xs'); 求解 关系 模式 的 候选 码 ， 判 断 关 系 模式 满足 第 几 范 式 。 

(6) 最 小 函数 依赖 集 ( 最 小 覆盖 ): 如 果 函 数 依赖 集 F 满足 下 列 条 件 , 则 称 下 为 一 个 极 小 
函数 依赖 集 ， 亦 称 为 最 小 依赖 集 或 最 小 覆盖 。 

e 下 中 任 一 函数 依赖 的 右 部 仅 含 有 一 个 属性 。 

e 下 中 不 存在 这 样 的 函数 依赖 X 一 A， 使 得 与 F-{X 一 A} 等 价 。 

。 下 中 不 存在 这 样 的 函数 依赖 X-*A，X 有 真子 集 Z 使 得 F-{X 一 A}U {Z 一 A} 与 F 等 价 。 








F 根 
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第 七 章 数据库 设计 


1. 数据 库 设计 

对 于 一 个 给 定 的 应 用 环境 ， 构 造 优化 的 数据 库 逻 辑 模式 和 物理 结构 ， 并 据 此 建立 数据 
库 及 其 应 用 系统 ， 使 之 能 够 有 效 地 存储 和 管理 数据 ， 满 足 各 种 用 户 的 应 用 需求 ， 包 括 信息 
管理 要 求 和 数据 操作 要 求 。 

2. 数据 库 设计 的 基本 步骤 


需求 分 析 ， 概 念 结构 设计 ， 风 辑 结构 设计 ， 物 理 结构 设计 ， 数 据 库 实施 ， 数 据 库 运 行 
和 维护 。 


3. 概念 结构 设计 


将 需求 分 析 得 到 的 用 户 需求 抽象 为 信息 结构 ， 即 概念 模型 的 过 程 。 也 就 是 通过 对 用 户 
需求 进行 综合 、 归 纳 与 抽象 ， 形 成 一 个 独立 于 具体 DBMS 的 概念 模型 。 


4. E-R 图 (用 来 描述 概念 模型 ) 


实体 型 : 用 珑 形 表示 ， 拢 形 框 内 写 明 实体 名 。 

属性 : 用 椭圆 形 表示 ， 并 用 无 向 边 将 其 与 相应 的 实体 型 连接 起 来 。 

联系 : 用 萎 形 表示 ， 萎 形 框 内 写 明 联系 名 ， 并 用 无 向 边 分 别 与 有 关 实 体 连接 起 来 ， 同 
时 在 无 向 边 旁 标 上 联系 的 类 型 (1 : 1、1 : n 或 m : n)。 

联系 的 属性 : 联系 本 身 也 是 一 种 实体 型 ， 也 可 以 有 属性 。 如 果 一 个 联系 具有 属性 ， 则 
这 些 属性 也 要 用 无 向 边 与 该 联系 连接 起 来 。 


5. 局 部 E-R 图 


绘制 局 部 E-R 图 是 概念 结构 设计 的 第 一 步 , 就 是 对 需求 分 析 阶 段 收 集 到 的 数据 进行 分 
类 、 组 织 ， 确 定 实体 、 实 体 的 属性 、 实 体 之 间 的 联系 类 型 。 

实体 与 属性 的 划分 原则 : 现实 世界 的 事物 能 作为 属性 对 待 的 尽量 作为 属性 对 待 。 

判定 为 属性 的 两 条 准则 : 作为 属性 ， 不 能 再 具有 需要 描述 的 性 质 ， 即 属性 必须 是 不 可 
分 的 数据 项 ， 不 能 包含 其 他 属性 ， 属 性 不 能 与 其 他 实体 具有 联系 。 

6. 全 局 E-R 图 


将 各 子 系统 的 局 部 E-R 图 集成 起 来 , 可 得 到 全 局 E-R 图 。E-R 图 的 集成 一 般 需 分 两 步 。 
e 合并 。 解 决 各 分 E-R 图 之 间 的 冲突 ， 将 分 ER 图 合并 起 来 生成 初步 ER 图 。 
。 修改 和 重 构 。 消 除 不 必要 的 元 余 ， 生 成 基本 ER 图。 
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逻辑 结构 设计 


将 概念 结构 模型 (基本 E-R 图 ) 转 换 为 某 个 DBMS 产品 所 支持 的 数据 模型 相符 合 的 逻辑 
结构 ， 并 对 其 进行 优化 。 

E-R 图 转换 为 关系 模型 实际 上 是 将 实体 型 、 实 体 的 属性 和 实体 之 间 的 联系 转换 为 关系 
模式 ， 转 换 原 则 如 下 。 

(1) 一 个 实体 型 转换 为 一 个 关系 模式 ， 关 系 的 属性 就 是 实体 的 属性 ， 关 系 的 码 就 是 实 
体 的 码 。 

(2) 对 于 实体 型 间 的 联系 则 根据 不 同 的 情况 进行 转换 。 


8. 


数 
DBMS 。 


一 个 1 : 1 联系 可 以 转换 为 一 个 独立 的 关系 模式 ， 也 可 以 与 任意 一 端 对 应 的 关系 模 
式 合并 。 

一 个 1 :nm 联系 可 以 转换 为 一 个 独立 关系 模式 ， 也 可 以 与 六 端 对 应 的 关系 模式 合并 。 
一 个 m : n 联系 转换 为 一 个 关系 模式 。 

3 个 或 3 个 以 上 实体 间 的 一 个 多 元 联系 可 以 转换 为 一 个 关系 模式 。 

具有 相同 码 的 关系 模式 可 合并 。 


物理 结构 设计 


据 库 在 物理 设备 上 的 存储 结构 与 存 取 方 法 称 为 数据 库 的 物理 结构 ， 它 依赖 于 选 定 的 


为 一 个 给 定 的 逻辑 数据 模型 选取 一 个 最 适合 应 用 要 求 的 物理 结构 的 过 程 ， 就 是 数据 库 
物理 结构 设计 。 数 据 库 物 理 结构 设计 可 分 以 下 两 步 。 


确定 数据 库 的 物理 结构 ， 在 关系 数据 库 中 主要 指 存 取 方 法 和 存储 结构 。 
对 物理 结构 进行 评价 ， 评 价 的 重点 是 时 间 和 空间 效率 。 


一 、 选 择 题 
1. 在 数据 管理 技术 的 发 展 过 程 中 , 经 历 了 人 工 管理 阶段 、 文 件 系统 阶段 和 数据 库 系 统 
阶段 。 在 这 几 个 阶段 中 ， 数 据 独立 性 最 高 的 是 阶段 。 
A. 数据 库 系 统 B. 文件 系统 C. 人 工 管理 D. 数据 项 管理 


【答案 : A】 
2. 数据 库 的 概念 模型 独立 于 
A. 具体 的 机 器 和 DBMS B. ER 图 
C. 信息 世界 D. 现实 世界 
【答案 : A】 


3. 数据 库 的 基本 特点 是 
A. (1) 数 据 可 以 共享 ” (2) 数 据 独 立 性 ” (3) 数 据 见 余 大 (4) 统 一 管理 和 控制 
B. (1) 数 据 可 以 共享 ” (2) 数 据 独 立 性 ” (3) 数 据 匈 余 小 (4) 统 一 管理 和 控制 
C. (1) 数 据 可 以 共享 ” (2) 数 据 互 换 性 。” (3) 数 据 见 余 小 (4) 统 一 管理 和 控制 
D. (1) 数 据 非 结构 化 (2) 数 据 独 立 性 (G3) 数据 匈 余 小 (4) 统 一 管理 和 控制 
【答案 : B】 


4. 是 存储 在 计算 机 内 有 结构 的 数据 的 集合 。 
A. 数据 库 系统 B. 数据 库 
C. 数据 库 管 理 系统 D. 数据 结构 
【答案 : B】 
5. 数据 库 中 存储 的 是 。 
A. 数据 B. 数据 模型 
C. 数据 及 数据 之 间 的 联系 D. 信息 
【答案 : C】 


6. 在 数据 库 中 ， 数 据 的 物理 独立 性 是 指 
A. 数据 库 与 数据 库 管理 系统 的 相互 独立 
B. 用 户 程序 与 DBMS 的 相互 独立 
C. 用 户 的 应 用 程序 与 存储 在 磁盘 上 数据 库 中 的 数据 是 相互 独立 的 
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D. 应 用 程序 与 数据 库 中 数据 的 逻辑 结构 相互 独立 
【答案 : C】 
7. 数据 库 的 特点 之 一 是 数据 的 共享 ， 严 格 地 讲 ， 这 里 的 数据 共享 是 指 
A. 同一 个 应 用 中 的 多 个 程序 共享 一 个 数据 集合 
B. 多 个 用 户 、 同 一 种 语言 共享 数据 
C. 多 个 用 户 共享 一 个 数据 文件 
D. 多 种 应 用 、 多 种 语言 、 多 个 用 户 相 互 覆 盖 地 使 用 数据 集合 
【答案 : D】 
8. 数据 库 系统 的 核心 是 


A. 数据 库 B. 数据 库 管理 系统 
C. 数据 模型 D. 软件 工具 
【答案 : B】 
9. 下 述 关 于 数据 库 系统 的 正确 叙述 是 。 


A. 数据 库 系统 减少 了 数据 见 余 

B. 数据 库 系统 避免 了 一 切 元 余 

C. 数据 库 系统 中 数据 的 一 致 性 是 指数 据 类 型 一 至 
D. 数据 库 系 统 比 文件 系统 能 管理 更 多 的 数据 

【答案 , A】 

10. 将 数据 库 的 结构 划分 成 多 个 层次 ， 是 为 了 提高 数据 库 的 “四 和 加  。 
CA. 数据 独立 性 B. 逻辑 独立 性 C. 管理 规范 性 。 D. 数据 的 共享 
@A. 数据 独立 性 B. 物理 独立 性 ”C. 逻辑 独立 性 ” D. 管理 规范 性 

【答案 : DB @B】 

11. 数据 库 (DB)、 数 据 库 系 统 (DBS) 和 数据 库 管理 系统 (DBMS) 三 者 之 间 的 关系 是 


A. DBS 包括 DB 和 DBMS B. DDMS 包括 DB 和 DBS 
C.DB 包括 DBS 和 DBMS D. DBS 就 是 DB， 也 就 是 DBMS 
【答案 : A】 
12. 在 数据 库 中 ， 产 生 数 据 不 一 致 的 根本 原因 是 
A. 数据 存储 量 太 大 B. 没有 严格 保护 数据 
C. 未 对 数据 进行 完整 性 控制 D. 数据 元 余 
【答案 : D】 
13. 数据 库 管理 系统 (DBMS) 是 
A. 数学 软件 B. 应 用 软件 
C. 计算 机 辅助 设计 D. 系统 软件 
【答案 : D】 
14. 数据 库 管 理 系 统 (DBMS) 的 主要 功能 是 
A. 修改 数据 库 B. 定义 数据 库 


C. 应 用 数据 库 D. 保护 数据 库 
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【答案 : B】 
15. 数据 库 系统 的 特点 是 、 数 据 独 立 、 减 少数 据 见 余 、 避 免 数 据 不 一 臻 和 加 
强 了 数据 保护 。 


A. 数据 共享 B. 数据 存储 C. 数据 应 用 D. 数据 保密 
【答案 : A】 
16. 数据 库 系统 的 最 大 特点 是 

A. 数据 的 三 级 抽象 和 二 级 独立 性 B. 数据 共享 性 

C. 数据 的 结构 化 D. 数据 独立 性 
【答案 : A】 
17. 数据 库 管理 系统 能 实现 对 数据 库 中 数据 的 查询 、 插 入 、 修 改 和 删除 等 操作 ， 这 种 

功能 称 为 

A. 数据 定义 功能 B. 数据 管理 功能 C. 数据 操纵 功能 D. 数据 控制 功能 
【答案 : C】 
18. 数据 库 管理 系统 是 








A. 操作 系统 的 一 部 分 B. 在 操作 系统 支持 下 的 系统 软件 
C. 一 种 编译 程序 D. 一 种 操作 系统 

【答案 : B】 

19. 数据 库 的 三 级 模式 结构 中 ， 描 述 数据 库 中 全 体 数 据 的 全 局 逻辑 结构 和 特征 的 
A. 外 模式 B. 内 模式 C. 存储 模式 D. 模式 

【答案 : D】 

20. 数据 库 系 统 的 数据 独立 性 是 指 


A. 不 会 因为 数据 的 变化 而 影响 应 用 程序 

B. 不 会 因为 系统 数据 存储 结构 与 数据 逻辑 结构 的 变化 而 影响 应 用 程序 
C. 不 会 因为 存储 策略 的 变化 而 影响 存储 结构 

D. 不 会 因为 某 些 存储 结构 的 变化 而 影响 其 他 的 存储 结构 








【答案 : B】 
21. 信息 世界 中 的 术语 ， 与 之 对 应 的 数据 库 术语 为 

A. 文件 B. 数据 库 C. 字段 D. 记录 
【答案 : D】 
22. 层次 型 、 网 状 型 和 关系 型 数据 库 划 分 原则 是 

A. 记录 长 度 B. 文件 的 大 小 

C. 联系 的 复杂 程度 D. 数据 之 间 的 联系 
【答案 : D】 
23. 传统 的 数据 模型 分 类 ， 数 据 库 系统 可 以 分 为 三 种 类 型 ; 

A. 大 型 、 中 型 和 小 型 B. 西 文 、 中 文 和 兼容 


C. 层次 、 网 状 和 关系 D. 数据 、 图 形 和 多 媒体 
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【答案 : C】 
24. 层次 模型 不 能 直接 表示 
1 : 1 关系 B. 1 : m 关 系 

C.m :nm 关系 D.1:1 和 1 :m 关 系 
【答案 : C】 
25. 数据 库 技术 的 奠基 人 之 一 EF.Codd 从 1970 年 起 发 表 过 多 篇 论文 ， 主 要 论述 的 

是  。 

A. 层次 数据 模型 B. 网 状 数据 模型 

C. 关系 数据 模型 D. 面向 对 象 数 据 模型 
【答案 : C】 
二 、 填 空 题 


1. 数据 管理 技术 经 历 了 _ 人 工 管理 文件 系统 _ 和 _ ”数据库 系统 _ 三 个 阶段 。 

2. 数据 库 是 长 期 存储 在 计算 机 内 、 有 本 名 4、 可 ”共享 _ 的 数据 集合 。 

3. DBMS 是 指 _ 数据 库 管 理 系统 , 它 是 位 于 _ 用 户 “ 和 操作 系统 _ 之 间 的 一 层 管理 
软件 。 

4. 数据 库 管理 系统 的 主要 功能 有 _ 数据 定义 功能 ” 、_ 数据 操纵 功能 、 数 据 库 的 
运行 管理 和 数据 库 的 建立 及 维护 4 个 方面 。 

5. 数据 独立 性 又 可 分 为 邮 辑 独立 性 和 物理 独立 性 __。 

6. 当 数 据 的 物理 存储 改变 ， 应 用 程序 不 变 ， 而 由 DBMS 处 理 这 种 改变 ， 这 是 指数 据 
的 _ 物理 独立 性 _。 

7. 数据 模型 是 由 __ 数据 结构 数据 操作 ”_ 和 __ 完整 性 约束 _ 三 部 分 组 成 的 。 

8._ 数据 结构 是 对 数据 系统 的 明太 特性 的 描述 ， 数据 操作 是 对 数据 库 系统 的 动态 特 
性 的 描述 。 

9. 数据 库 体系 结构 按照 _ 模 式 。” 、_ 外 模式 ”和 _ 内 模式 ”三 级 结构 进行 组 织 。 

10. 实体 之 间 的 联系 可 抽象 为 三 类 , 它们 是 1:1 、_1L:m 和 _ m:n。 

11. 数据 元 余 可 能 导致 的 问题 有 _ ”浪费 存储 空间 及 修改 麻烦 “和 潜在 的 数据 不 一 


12. 经 过 加 工 提炼 而 用 于 决策 或 其 他 应 用 活动 的 数据 称 为 信息。 
13. 按照 数据 结构 的 类 型 来 命名 ， 数 据 模型 分 为 _ 层 次 模型 ” 、_ 网 状 模型 和 _ 关系 


14. 非 关系 模型 中 数据 结构 的 基本 单位 是 _ 基 本 层次 联系 _。 
15. 根据 数据 模型 应 用 目的 的 不 同 ,数据 模型 可 分 _ 概念 模型 “、_ 数据 模型 、_ 数 据 








16. 负责 全 面 管理 和 控制 数据 库 系 统 的 人 员 叫 _DBA _。 
17. 数据 描述 语言 的 作用 是 ”定义 数据 库 _。 
18. 关系 数据 库 采 用 _ 关系 模型 _ 作 为 数据 的 组 织 方式 。 
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19. 层次 数据 模型 中 ， 只 有 一 个 结 点 ， 无 父 结 点 ， 它 称 为 _ 根 _。 
20.， 数据 结构 ”是 存储 在 计算 机 内 有 结构 的 数据 的 集合 。 


三 、 简 答题 


1. 什么 是 数据 库 ? 

答 : 数据 库 是 长 期 存储 在 计算 机 内 、 有 组 织 的 、 可 共享 的 数据 集合 。 数 据 库 是 按 某 种 
数据 模型 进行 组 织 的、 存放 在 外 存储 器 上 ， 且 可 被 多 个 用 户 同时 使 用 。 因 此 ， 数 据 库 具 有 
较 小 的 元 余 度 、 较 高 的 数据 独立 性 和 易 扩 展 性 。 

2. 什么 是 数据 库 的 数据 独立 性 ? 

答 : 数据 独立 性 表示 应 用 程序 与 数据 库 中 存储 的 数据 不 存在 依赖 关系 ， 包 括 逻辑 数据 
独立 性 和 物理 数据 独立 性 。 

逻辑 数据 独立 性 是 指 局 部 逻辑 数据 结构 (外 视图 ， 即 用 户 的 轴 辑 文件 ) 与 全 局 逻辑 数据 
结构 (概念 视图 ) 之 间 的 独立 性 。 当 数据 库 的 全 局 逻辑 数据 结构 (概念 视图 ) 发 生变 化 (数据 定 
义 的 修改 、 数 据 之 间 联 系 的 变更 或 增加 新 的 数据 类 型 等 ) 时 ， 它 不 影响 某 些 局 部 的 逻辑 结构 
的 性 质 ， 应 用 程序 不 必修 改 。 

物理 数据 独立 性 是 指数 据 的 存储 结构 与 存 取 方 法 (内 视图 ) 改 变 时 ， 对 数据 库 的 全 局 轴 
辑 结构 ( 概 念 视图 ) 和 应 用 程序 不 必 作 修改 的 一 种 特性 ， 也 就 是 说 ， 数 据 库 数据 的 存储 结构 
与 存 取 方法 独立 。 

3. 什么 是 数据 库 管 理 系统 ? 

答 : 数据 库 管理 系统 (DBMS) 是 操纵 和 管理 数据 库 的 一 组 软件 ， 它 是 数据 库 系统 (DBS) 
的 重要 组 成 部 分 。 不 同 的 数据 库 系统 都 配 有 各 自 的 DBMS, 而 不 同 的 DBMS 各 支持 一 种 数 
据 库 模 型 ， 虽 然 它 们 的 功能 强 弱 不 同 ， 但 大 多 数 DBMS 的 构成 相同 ， 功 能 相似 。 

一 般 说 来 , DBMS 具有 定义 、 建 立 、 维护 和 使 用 数据 库 的 功能 ， 它 通常 由 三 部 分 构成 : 
数据 描述 语言 及 其 翻译 程序 、 数 据 操 纵 语言 及 其 处 理 程序 和 数据 库 管理 的 例 行 程序 。 

4. 什么 是 数据 字典 ?数据 字典 包含 哪些 基本 内 容 ? 

答 : 数据 字典 是 数据 库 系统 中 各 种 描述 信息 和 控制 信息 的 集合 ， 它 是 数据 库 设 计 与 管 
理 的 有 力 工具 ， 是 进行 详细 数据 收集 和 数据 分 析 所 获得 的 主要 成 果 。 数 据 字典 的 基本 内 容 
有 数据 项 、 数 据 结构 、 数 据 流 、 数 据 存储 和 处 理 过 程 5 个 部 分 。 

5. 简 述 数据 模型 的 三 要 素 及 功能 。 

答 : 数据 模型 是 数据 库 中 对 现实 世界 进行 抽象 的 工具 ， 是 数据 库 中 用 于 提供 信息 表示 
和 操作 手段 的 形式 构架 。 它 是 一 组 严格 定义 的 概念 集合 。 

数据 模型 的 三 要 素 是 数据 结构 、 数 据 操作 、 完 整 性 约束 。 
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第 二 章 关系 数据 库 





一 、 选 择 题 
1. 关系 数据 库 管 理 系 统 应 能 实现 的 专门 关系 运算 包括 
A. 排序 、 索 引 、 统 计 B. 选择 、 投 影 、 连 接 
C. 关联 、 更 新 、 排 序 D. 显示 、 打 印 、 制 表 
【答案 : B】 


2. 关系 模型 中 ， 一 个 关键 字 是 
A. 可 由 多 个 任意 属性 组 成 
B. 至 多 由 一 个 属性 组 成 
C. 可 由 一 个 或 多 个 其 值 能 唯一 标识 该 关系 模式 中 任何 元 组 的 属性 组 
D. 以 上 都 不 是 

















【答案 : C】 
3. 自然 连接 是 构成 新 关系 的 有 效 方法 。 一 般 情况 下 ， 当 对 关系 R 和 S 使 用 自然 连接 
时 ， 要 求 R 和 S 含有 一 个 或 多 个 共有 的 和 
A. 元 组 B. 行 C. 记录 D. 属性 
【答案 : D】 
4. 关系 运算 中 花费 时 间 可 能 最 长 的 运算 是 
A. 投影 B. 选择 C. 第 卡尔 积 D. 除 
【答案 :; C】 
5. 关系 模式 的 任何 属性 
A. 不 可 再 分 B. 可 再 分 
C. 命名 在 该 关系 模式 中 可 以 不 唯一 D. 以 上 都 不 是 
【答案 : A】 


6. 在 关系 代数 运算 中 ， 五 种 基本 运算 为 。 
A. 并 、 差 、 选 择 、 投 影 、 自 然 连接 
B. 并 、 差 、 交 、 选 择 、 投 影 
C. 并 、 差 、 选 择 、 投 影 、 笛 卡尔 积 
D. 并 、 差 、 交 、 选 择 、 笛 卡尔 积 


【答案 : C】 

7. 设 有 关系 RR， 按 条 件 f 对 关系 R 进行 选择 ， 正 确 的 是 。 
A. RXR B.R PR C. ofR) D. TI{(R) 

【答案 : C】 


8. 设 关系 尺 和 S 的 元 组 个 数 分 别 为 100 和 300， 关 系 工 是 及 与 S 的 笛 卡尔 积 ， 则 工 
的 元 组 个 数 是 a 
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A.100 B. 300 C.400 D. 30000 
【答案 : D】 
9. 如 下 图 所 示 ， 两 个 关系 Rl1 和 R2， 它 们 进行 运算 后 得 到 R3。 
A. 交 B: 并 C. 第 卡 尔 积 D. 连接 
【答案 : D】 
Rl1 R2 R3 
| A B | Ee B D E A | B | [9 D | E 
A | ,9 1 M|I 疙 1 苇 MI|I 
纪 有 启 2 N 前 D 1 Y M |I 
D y 5 M | 已 y N J 











10. 设 有 如 下 图 所 示 的 关系 R， 经 操作 IIAB(aB-2(R)) (II 为 “投影 ”运算 符 ，o 为 “ 选 
择 ” ) 的 运算 结果 是 
【答案 : C】 





2. 一 个 关系 模式 的 定义 主要 包括 _ 关系 名 、 属性 名 属性 类型 属性 K 度 
和 _ 关键 字 。 

3. 关系 代数 运算 中 ， 传 统 的 集合 运算 有 __ 笛 卡尔 积 _、 并 、 交 
和 差 。 

4. 关系 代数 运算 中 ， 基 本 的 运算 是 _ 并 _、_ 差 、_ 笛 卡尔 积 _、 投影 和 

选择 

5. 关系 代数 运算 中 , 专门 的 关系 运算 有 选择” 、_ 投影 和 连接 5 

6. 关系 数据 库 中 基于 数学 的 两 类 运算 是 关系 代数 和 ”关系 演算 。 

7. 关系 操作 的 特点 是 __ 集合 操作 。 

8. 关系 模式 是 关系 的 __ 框架 _， 相 当 于 ”记录 格式 。 

9 在 个 妆 休 突 不 全 时 由， 称 能 唯一 标识 实体 的 属性 或 属性 组 为 ”关键 字 ( 码 ) 。 

10. 传统 的 集合 “并 , 交 , 差 ” 运 算 施 加 于 两 个 关系 时 ,这 两 个 关系 的 _ 属 性 个 数 _ 必 
须 相 等 ， et 必须 取 自 同一 个 域 。 

11. 关系 代数 是 用 对 关系 的 运算 来 表达 查询 的 ， 而 关系 演算 是 用 _ 谓词 ”来 表达 查询 
的 ， 它 又 可 分 为 ”元 组 关系 ”和 _ 域 关 系 
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12. 同一 关系 模型 中 的 任 两 个 元 组 值 不 能 完全 相同 _。 
13. 关系 的 三 类 完整 性 约束 分 别 是 _ 实 体 完整 性 、_ 参 照 完整 性 “和 

















户 定义 的 完 








14. 已 知 系 ( 系 编号 ， 系 名 称 ， 系 主任 ， 电 话 ， 地 点 ) 和 学 生 ( 学 号 ， 姓 名 ， 性 别 ， 入 学 
日 期 ,专业 , 系 编号 ) 两 个 关系 , 系 关系 的 主 关键 字 是 _ 系 编号 系 关 系 的 外 关键 字 是 无 _， 
学 生 关系 的 主 关键 字 是 _ 学 号 ， 外 关键 字 是 _ 系 编号 。 

15. 在 学 生 ( 学 号 ， 姓 名 ， 性 别 ， 年 龄 ， 班 长 学 号 )、 课 程 (课程 号 ， 课 程 名 ， 学 时 数 )、 
选修 (学 号 ， 课 程 号 ， 成 绩 ) 三 个 关系 中 : 

选修 关系 的 主 码 是 _ 学 号 + 课程 号 ， 外 码 _ 学 号 “参照 学 生 关系 的 主 码 ， 外 码 _ 课 
程 号 _ 参 照 课程 关系 的 主 码 。 

学 生 关系 的 主 码 是 _ 学 号 ， 外 码 是 _ 班 长 学 号 ， 参 照 学生 关系 的 主 码 。 

三 、 问 答题 

1. 简 述 基本 关系 的 性 质 。 

答 : 关系 一 一 规范 化 的 二 维 表格 ， 其 主要 性 质 有 以 下 几 点 。 

@ 列 是 同 质 的 ， 即 每 一 列 中 的 分 量 是 同一 类 型 的 数据 ， 来 自 同一 个 域 ( 列 同型 )。 

@ 不 同 的 列 可 出 自 同一 个 域 ， 称 其 中 的 每 一 列 为 一 个 属性 ， 不 同 的 属性 要 给 予 不 同 
的 属性 名 。 

@ 列 的 顺序 无 所 谓 ， 即 列 的 次 序 可 以 任意 交换 。 

@ 任意 两 个 元 组 不 能 完全 相同 ( 行 相 异 )。 

@ 行 的 顺序 无 所 谓 ， 即 行 的 次 序 可 以 任意 交换 。 

@ 分 量 必须 取 原 子 值 ， 即 每 一 个 分 量 都 必须 是 不 可 分 的 数据 项 。 

2. 写 出 关系 模式 的 五 元 组 形式 化 表示 ， 并 说 明 各 符号 的 含义 。 

答 : 关系 模式 是 对 关系 的 描述 ， 形 式 化 表示 为 RU，D，DOM，F)。 

R 一 一 关系 名 ; 

U 一 一 组 成 该 关系 的 属性 名 集合 ; 

D 一 一 属性 组 U 中 属性 所 来 自 的 域 ; 

DOM 一 一 属性 向 域 的 映 象 集合 ; 

F 一 一 属性 间 的 数据 依赖 关系 集合 。 

3. 设 尺 是 包含 Ji 个 元 组 的 na 目 关 系 ，S 是 包含 ks 个 元 组 的 m 目 关系 , 写 出 R 与 S$ 的 
笛 卡 尔 积 运算 公式 ， 并 说 明 其 含义 。 

答 : 运算 公式 为 RXS= {ttltre RAte S}。 

运算 结果 为 一 个 (ntm) 目 关系 ， 其 每 个 元 组 的 前 n 列 是 关系 及 的 一 个 元 组 ， 后 m 列 是 
关系 S 的 一 个 元 组 。 运 算 结果 包含 由 ki Xk 个 元 组 ， 由 来 自 R 和 S 的 所 有 元 组 交叉 组 合 
而 成 。 
4. 简 述 自然 连接 和 等 值 连接 的 区 别 和 联系 。 
答 : 自然 连接 一 定 是 等 值 连接 ， 但 等 值 连接 不 一 定 是 自然 连接 。 





所 
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等 值 连接 要 求 相等 的 分 量 ， 不 一 定 是 公共 属性 ;而 自然 连接 要 求 相等 的 分 量 一 定 是 公 
属性 。 
等 值 连接 不 把 重复 的 属性 去 掉 ， 而 自然 连接 要 把 重复 的 属性 去 掉 。 


四 、 应 用 题 


设 有 如 下 所 示 的 关系 S(CS# SNAME.AGE.SEX)、C(C#CNAME,TEACHER) 和 SC(S##C## 

















GRADE)， 试 用 关系 代数 表达 式 表 示 下 列 查询 语句 。 








(1) 检索 “ 程 军 ” 老 师 所 授课 程 的 课程 号 (C 约 和 课程 名 (CNAME)。 

(2) 检索 年 龄 大 于 21 的 男 学 生 的 学 号 (S 雪 和 姓名 (SNAME)。 

(3) 检索 至 少 选 修 “ 程 军 ” 老 师 所 授 全 部 课程 的 学 生 姓 名 (SNAME)。 
(4) 检索 “李强 ”同学 未 选修 课程 的 课程 号 (C 雪 。 

(5) 检索 至 少 选修 两 门 课程 的 学 生 的 学 号 (S 均 。 

(6) 检索 全 部 学 生 都 选修 的 课程 的 课程 号 (C 胡 和 课程 名 (CNAME)。 

(7) 检索 选修 课程 包含 “ 程 军 ” 老 师 所 授课 程 之 一 的 学 生 的 学 号 (S 均 。 
(8) 检索 选修 课程 号 为 kl 和 ks 的 学 生 的 学 号 (S 均 。 

(9) 检索 选修 全 部 课程 的 学 生 的 姓名 (SNAME)。 

(10) 检索 所 选修 的 课程 包含 学 号 为 2 的 学 生 所 修 课程 的 学 生 学 号 (S 坎 。 
(11) 检索 选修 课程 名 为 “C 语言 ”的 学 生 的 学 号 (S 胡 和 姓名 (SNAME)。 
【解答 】 本 题 各 个 查询 语句 对 应 的 关系 代数 表达 式 表示 如 下 。 


(1) TIcscNawe(GreaAcHER-eF(C)) 





(2) TIsssNaMe(GAGE>2lAsEx=%(C)) 

(3) TIswave {SD [IIsscs(SC)=[Icy(GreAcaER-ee(C))]} 
(4) Tle#(O- [es(Gsvave—#%(S)D<SC) 

(5) TIsw(ar-mAPFGISCxSC)) 

(6) Tles.cxave(CDA (Is#ca(SC)-TIs#(S))) 

(7) Ils#(SCDA TIes(GreacHer=R*(C))) 

(8) TIsscs(SC)TIcx(aGcs=xurvcs=xs(C)) 

(9) Tlsvave {SD [TIs# ca(SO) TIO 

(10) [Iswcx(SC)=TIcxcs-> (SC)) 

(11) Tlssswave {SPA [TIss(SCD< ocwame-c wi(C))]} 
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第 三 章 关系 数据 库 标 准 语言 SQL 


一 、 选 择 题 
1. SQL 语言 是 的 语言 ， 易 于 学 习 。 
A. 过 程 化 B. 非 过 程 化 C. 格式 化 D. 导航 式 
【答案 : B】 
2. SQL 语言 是 语言 。 


A. 层次 数据 库 B. 网 络 数据 库 ” C. 关系 数据 库 ” D. 非 数 据 库 
【答案 : C】 
3. SQL 语言 具有 的 功能 。 

A. 关系 规范 化 、 数 据 操纵 、 数 据 控制 

B. 数据 定义 、 数 据 操纵 、 数 据 控制 

C. 数据 定义 、 关 系 规范 化 、 数 据 控制 

D. 数据 定义 、 关 系 规范 化 、 数 据 操纵 
【答案 : B】 
4. SQL 语言 具有 两 种 使 用 方式 ， 分 别称 为 交互 式 SQL 和 

A. 提示 式 SQL ” B. 多 用 户 SQL CC. 嵌入 式 SQL ”D. 解释 式 SQL 
【答案 : C】 
5. SQL 语言 最 主要 功能 是 

A. 数据 定义 功能 ” B. 数据 操纵 功能 C. 数据 查询 D. 数据 控制 
【答案 : C】 





6. 在 SQL 语言 中 授权 的 操作 是 通过 语句 实现 的 。 

A. CREATE B. REVOKE C.GRANT D. INSERT 
【答案 : C】 
7. 下 列 SQL 语言 中 ， 修 改 表 结 构 的 语句 为 

A. ALTER B. CREATE C. UPDATE D. INSERT 
【答案 : A】 
8. 关于 SQL 语言 ， 下 列 说 法 正确 的 是 . 


A. 数据 控制 功能 不 是 SQL 语言 的 功能 之 一 
B. SQL 采用 的 是 面向 记录 的 操作 方式 ， 以 记录 为 单位 进行 操作 
C. SQL 是 非 过 程 化 的 语言 ， 用 户 无 须 指定 存 取 路 径 
D. SQL 作为 嵌入 式 语 言语 法 与 独立 的 语言 有 较 大 差别 
【答案 : C】 
9. 数据 库 中 建立 索引 是 为 了 
A. 加 快 建 表 速度 B. 加 快 存 取 速 度 
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C. 提高 安全 性 D. 节省 存储 空间 
【答案 : B】 
10. 视图 是 数据 库 系 统 三 级 模式 中 的 
A. 外 模式 B. 模式 C. 内 模式 D. 模式 映像 
【答案 : A】 
11. 下 列 说 法 不 正确 的 是 5 


A. 基本 表 和 视图 一 样 ， 都 是 关系 
B. 可 以 使 用 SQL 对 基本 表 和 视图 进行 操作 
C. 可 以 从 基本 表 和 视图 上 定义 视图 
D. 基本 表 和 视图 中 都 存储 数据 
【答案 : D】 
12. 假定 学 生 关系 是 S(S# SNAMEm, SEX, AGE), 课程 关系 是 C(C#, CNAME, TEACHER)， 
学 生 选 课 关 系 是 SC(S#, C#, GRADE)。 





要 查找 选修 COMPUTER 课程 的 “ 女 ” 学 生 姓名 ， 将 涉及 关系 。 
A.S B.SC，C C.S，SC D.S，C，SC 
【答案 : D】 


13. 假定 职工 表 的 主 关 键 字 是 职工 号 , 部 门 表 的 主 关 键 字 是 部 门 号 ,以 下 SQL___ 操 
作 不 能 执行 。 
A. 从 职工 表 中 删除 行 (025', ' 王 芳 ', '03', 720) 
B. 将 行 (005', ' 乔 兴 ', '04', 750) 插 入 职工 表 中 
C. 将 职工 号 为 001 的 工资 改 为 700 
D. 将 职工 号 为 038 的 部 门 号 改 为 03 
【答案 : B】 
14. 若 用 如 下 SQL 语句 创建 一 个 student 表 : 
CREATE TABLE student( 
NO C(4) NOT NULL, 
NAME C(8) NOT NULL, 
SEX C(2), 
AGE NOCO) 
} 
可 以 插入 student 表 中 的 是 
A.(1031', ' 曾 华 ', ' 男 ', 23) 
B.(1031', ' 曾 华 ', NULL NULL) 
C. (NULL, ' 曾 华 ', ' 男 ', 23) 
D. (1031', NULL, ' 男 ', 23) 
【答案 : B】 
第 15 到 第 18 题 基 于 这 样 的 三 个 表 ， 即 学 生 表 S、 课 程 表 C 和 学 生 选 课表 SC， 它 们 
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的 结构 如 下 : 


S(S# SN, SEX AGE, DEPT) 
CCC# CN) 
SC(S#, C#. GRADE) 
其 中 S# 为 学 号 ，SN 为 姓名 ，SEX 为 性 别 ，AGE 为 年 龄 ，DEPT 为 系 别 ，C# 为 课程 
号 ，CN 为 课程 名 ，GRADE 为 成 绩 。 
15. 检索 所 有 比 “ 王 华 ” 年 龄 大 的 学 生 姓名 、 年 龄 和 性 别 。 正 确 的 SELECT 语句 


[a 
下 o 





A. SELECT SN, AGE, SEX FROMS 
WHERE AGE> (SELECT AGE FROM S 
WHERE SN=' 王 华 ') 
B. SELECT SN, AGE, SEX 
FROMS 
WHERE SN==' 主 华 ' 
C. SELECT SN, AGE, SEX FROMS 
WHERE AGE> (SELECT AGE 
WHERE SN=' 王 华 ) 
D. SELECT SN,AGE, SEX FROMS 
WHERE AGE> 王 华 .AGE 
【答案 : A】 
16. 检索 选修 课程 C2 的 学 生 中 成 绩 最 高 的 学 生 的 学 号 ， 正 确 的 SELECT 语句 
A. SELECT S# FORM SC 
WHERE C#='C2' AND 
GRAD> =(SELECT GRADE FORM SC 
WHERE C#='C2') 
B. SELECT S#FORM SC 
WHERE C#='C2' AND GRADE IN 
(SELECT GRADE FORM SC 
WHERE C#='C2') 
C. SELECT S# FORM SC 
WHERE C#='C2' AND GRADE NOTIN 
(SELECT GRADE FORM SC 
WHERE C#='C2') 
D. SELECT S#FORM SC 


WHERE C#='C2' AND GRADE> =ALL 
(SELECT GRADE FORM SC 
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WHERE C#='C2') 
【答案 : D】 
17. 检索 学 生 姓名 及 其 所 选修 课程 的 课程 号 和 成 绩 , 正确 的 SELECT 语句 是 
A. SELECT S. SN, SC. C# SC. GRADE 
FROM S 














WHERE S. S#=SC. S# 
B. SELECT S. SN, SC. C# SC. GRADE 
FROM SC 
WHERE S. S# 一 SC. GRADE 
C. SELECT S. SN, SC. C# SC. GRADE 
FROM S, SC 
WHERE S. S#=SC. S# 
D. SELECT S. SN, SC. C# SC. GRADE 


FROM S. SC 
【答案 : C】 
18. 检索 选修 四 门 以 上 课程 的 学 生 总 成 绩 ( 不 统计 不 及 格 的 课程 ), 并 要 求 按 总 成 绩 的 降 
序 排 列 出 来 ， 正 确 的 SELECT 语句 是 a 
A. SELECT S#, SUM(GRADE)FROM SC 
WHERE GRADE>=60 
GROUP BY S# 
ORDER BY 2 DESC 
HAVING COUNT(*)>=4 WHERE C#-'C2'AND 
GRADE>= 
(SELECT GRADE FORM SC 
WHERE C#='C2') 


B. SELECT S# FORM SC 
WHERE Ct#F'C2' AND GRADE IN 
(SELECT GRADE FORM SC 
WHERE C#='C2") 
C. SELECT S# FORM SC 
WHERE C#='C2' AND GRADENOT IN 
(SELECT GRADE FORM SC 
WHERE C#='C2') 
D. SELECT S# FORM SC 
WHERE C#='C2' AND GRADE> =ALL 
(SELECT GRADE FORM SC 
WHERE C#='C2' 
【答案 : D】 
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二 、 填 空 题 

1. SQL 是 ”结构 化 查询 语言 

2. 视图 是 一 个 虚 表 ， 它 是 从 ”一 个 或 几 个 基本 表 ”中 导出 的 表 。 在 数据 库 中 ， 只 存放 
视图 的 _ 定义， 不 存放 视图 对 应 的 数据 。 

3. SQL 数据 定义 语句 的 操作 对 象 有 _ 模 式 _、._ 表 、._ 视 图 和 索引 。 

















4. SQL 数据 定义 语句 的 命令 动词 是 CREATE 、_DROP 和 ALTER 
5. RDBMS 中 索引 一 般 采 用 _B+ 树 ”或 HASH 来 实现 。 
6. 索引 可 以 分 为 _ 唯 一 索引 、_ 非 唯一 索引 和 聚 徐 索 引 三 种 类 型 。 
7. 设 有 如 下 关系 表 R: 
R(No, NAME, SEX, AGE, CLASS) 
主 关键 字 是 NO,， 





其 中 NO 为 学 号 ，NAME 为 姓名 ，SEX 为 性 别 ，AGE 为 年 龄 ，CLASS 为 班 号 。 
写 出 实现 下 列 功能 的 SQL 语句 。 


@ 插入 一 个 记录 (25," 李 明 '' 男 , 21,'95031"): 
@ 插入 95031 班 学 号 为 30、 姓 名 为 “ 郑 和 ”的 学 生 记录 : ， 
@ 将 学 号 为 10 的 学 生 姓名 改 为 “ 王 华 ”: 5 
@ 将 所 有 95101 班 号 改 为 95091: 
@ 删除 学 号 为 20 的 学 生 记录 : 后 
@ 删除 姓 “ 王 ”的 学 生 记录 : 
【解答 】 


@ INSERT INTOR VALUES(25, ' 李 明 ',' 男 , 21, 95031) 

@ INSERTINTO R(NO, NAME, CLASS) VALUES(30,' 郑 和 ','95031") 
@ UPDATE R SET NAME=' 王 华 ' WHERE NO=10 

@ UPDATE R SET CLASS='95091' WHERE CLASS="'95101' 

@@ DELETE FROMR WHERE NO=20 

@ DELETE FROMR WHERE NAME LIKE'E%' 


三 、 应 用 题 


1. 设 学 生 课程 数据 库 中 有 三 个 关系 : 

学 生 关系 S(S#, SNAME, AGE, SEX) 

学 习 关系 SC(S#. C#, GRADE) 

课程 关系 C(C#, CNAME) 

其 中 S#、C#、SNAME、AGE、SEX、GRADE、CNAME 分 别 表示 学 号 、 课 程 号 、 姓 
名 、 年 龄 、 性 别 、 成 绩 和 课程 名 。 

用 SQL 语句 表达 下 列 操 作 。 

(1) 检索 选修 课程 名 称 为 MATHS 的 学 生 的 学 号 与 姓名 。 
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(2) 检索 至 少 学 习 了 课程 号 为 Cl 和 C2 的 学 生 的 学 号 。 
(3) 检索 年 龄 在 18 一 20 之 间 ( 含 18 和 20) 的 女生 的 学 号 、 姓 名 和 年 龄 。 
(4) 检索 平均 成 绩 超过 80 分 的 学 生 学 号 和 平均 成 绩 。 
(5) 检索 选修 了 全 部 课程 的 学 生 姓名 。 
(6) 检索 选修 了 三 门 课 以 上 的 学 生 的 姓名 。 
(7) 查询 所 有 比 “ 王 华 ”年 龄 大 的 学 生 姓 名 、 年 龄 和 性 别 。 
(8) 检索 学 生 姓名 及 其 所 选修 课程 的 课程 号 和 成 绩 。 
(9) 检索 选修 3 号 课程 的 学 生 姓 名 和 成 绩 。 
(10) 查询 选修 了 课程 名 为 “数据 库 ” 的 学 生 学 号 和 姓名 。 
(11) 定义 一 个 反映 学 生出 生年 份 的 视图 。 
(12) 将 学 生 的 学 号 及 他 的 平均 成 绩 定义 为 一 个 视图 。 
【解答 】 
(1) SELECT SNAME.AGE 
FROM S,SC:C 
WHERE S.S#=SC.S# 
AND C.C#=SC.C# 
AND CNAME=' MATHS'; 
(2) SELECT S# 





FROM SC 
WHERE CNO="C1’ AND S#IN (SELECT S# 

FROM SC 

WHERE CNO='C29: 


(3) SELECT S#SNAME,AGE 
FROMS 
WHERE AGE BETWEEN 18 AND 20; 
(4) SELECT S# ,AVG(GRADE) 平均 成 绩 ' 
FROM SC 
GROUP BY S# 
HAVING AVG(GRADE)>80: 
(5) SELECT SNAME 
FROMS 
WHERE NOT EXISTS 
(SELECT* 
FROM C 
WHERE NOTEXISTS 
(SELECT* 
FROM SC 
WHERE S#=S.S# AND C#=C.C# 
bs 
); 
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(6) SELECT SNAME 
FROM S,SC 
WHERE S.S#=SC.S# 
GROUPBY SNAME 


HAVING COUNT(*)>3; 


(7) SELECT SNAME ,AGE 
FROMS 


,SEX 


WHERE AGE>(SELECT AGE FROMS 
WHERE SNAME=' 王 华 '); 
(8) SELECT S.SNAME ,SC.C# SC.GRADE 


FROM S, SC 
WHERE S.S#=SC.S#; 


(9) SELEC S.SNAME ,SC.GRADE 


FROM S.SC 


WHERE S.S#=SC.S# AND C#='3"; 


(10) SELECT S# Sname 
FROMS,SC,C 
WHERE S.S#=SC.S# 
AND SC.C#=C.C# 


AND C.Cname=' 数 据 库 '; 
(11) CREATE VIEW BT_S ( S#, Sname, Sbirth) 


AS 


SELECT S# SNAME, 2003-age 


FROM S; 


(12) CREAT VIEW S_AVG (S# Savg) 


AS 


SELECT S#, AVG(Grade) 


FROM SC 
GROUP BY S#; 


2. 设 学 生 一 课程 数据 库 中 包括 以 下 三 个 表 。 

学 生 表 : Student (Sno, Sname, Sex, Sage, Sdept) 

课程 表 : Course(Cno, Cname, Ceredit) 

学 生 选 课表 : SC(Sno, Cno, Grade) 

其 中 Sno、Sname、Sex、Sage、Sdept、Cno、Cname、Ccredit、Grade 分 别 表示 学 号 、 
姓名 、 性 别 、 年 龄 、 所 在 系 名 、 课 程 号、 课程 名 、 学 分 和 成 绩 。 





试用 SQL 语言 完成 下 列 
(1) 查询 选修 课程 包括 1 


项 操作 。 
042 号 学 生 所 学 的 课程 的 学 生 学 号 。 


(2) 创建 一 个 计 科 系 学 生 信息 视图 S CS_VIEW, 包括 Sno 学 号 、Sname 姓名 、Sex 性 别 。 


(3) 通过 上 面 第 (2) 题 创 于 





的 视图 修改 数据 ， 把 王 平 的 名 字 改 为 王 慧 平 。 


(4) 创建 一 个 选修 数据 库 课 程 信息 的 视图 ， 视 图 名 称 为 datascore_view， 包 含 学 号 、 姓 





名 、 成 绩 。 
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【解答 】 
(1) SELECT DISTINCT SNO 
FROM SC SCX 
WHERE NOT EXISTS 
(SELECT* 
FROM SC SCY 
WHERE SCYSNO ='1042'AND 
NOTEXISTS 
(SELECT* 
FROM SC SCZ 
WHERE SCZ.SNO=SCX.SNO AND 
SCZ.CNO=SCY.CNO)): 
(2) CREATE VIEWS_CS_VIEW 
AS 
SELECT SNO,SNAME,SEX 
FROM STUDENT 
WHERE Sdept='CS'; 
(3) UPDATE S_CS VIEW 
SET SNAME=' 王 慧 平 ' 
WHERE SNAME=' 王 平 '; 
(4) CREATE VIEW datascore_view 
AS 
SELECT SNO, SNAME, GRADE 
FROM STUDENT'SC,COURSE 
WHERE STUDENTSNO=SC.SNO 
AND COURSE.CNO=SC.CNO 
AND CNAME=' 数 据 库 ': 


第 四 章 ”数据 库 的 安全 性 





一 、 选 择 题 

1. 下 面 哪个 不 是 数据 库 系统 必须 提供 的 数据 控制 功能 : 。 
A. 安全 性 B. 可 移植 性 C. 完整 性 D. 并 发 控制 

【答案 : B】 


2. 保护 数据 库 ， 防 止 未 经 授权 的 或 不 合法 的 使 用 造成 的 数据 泄漏 、 更 改 破坏 ， 这 是 指 
数据 的 


A. 安全 性 B. 完整 性 C. 并 发 控制 D. 恢复 
【答案 : A】 
3. 数据 库 的 是 指数 据 的 正确 性 和 相 容 性 。 


A. 安全 性 ”B. 完整 性 C. 并 发 控制 D. 恢复 
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【答案 : B】 
4. 在 数据 系统 中 ， 对 存 取 权 限 的 定义 称 为 
A. 命令 B. 授权 GG 十 义 D. 审计 
【答案 : B】 
5. 数据 库 管 理 系统 通常 提供 授权 功能 来 控制 不 同 用 户 访问 数据 的 权限 , 这 主要 是 为 了 
实现 数据 库 的 _ ___。 
A. 可 靠 性 B. 一 致 性 C. 完整 性 D. 安全 性 
【答案 : D】 
6. 下 列 SQL 语句 中 , 能够 实现 “收回 用 户 ZHAO 对 学 生 表 (STUD) 中 学 号 (XH) 的 修改 
权 ” 这 一 功能 的 是 a 


A. REVOKE UPDATE(XH) ON TABLE FROM ZHAO 
B. REVOKE UPDATE(XH) ON TABLE FROM PUBLIC 
C. REVOKE UPDATE(XH) ON STUD FROM ZHAO 
D. REVOKE UPDATE(XH) ON STUD FROM PUBLIC 


【答案 : C】 


T 


把 对 关系 SC 的 属性 GRADE 的 修改 权 授 予 用 户 ZHAO 的 SQL 语句 是 8 
A. GRANT GRADE ON SC TO ZHAO 

B. GRANT UPDATE ON SC TO ZHAO 

C. GRANT UPDATE (GRADE) ON SC TO ZHAO 

D. GRANT UPDATE ON SC (GRADE) TO ZHAO 





【答案 : C】 
8. 在 SQL Server 中 删除 触发 器 用 
A. ROLLBACK B. DROP 
C. DELALLOCATE D. DELETE 
【答案 : B】 
9. SQL 的 GRANT 和 REVOKE 语句 可 以 用 来 实现 
A. 自主 存 取 控制 B. 强制 存 取 控制 
C. 数据 库 角 色 创 建 D. 数据 库 审 计 
【答案 : A】 
10. 在 强制 存 取 控制 机 制 中 ， 当 主体 的 许可 证 级 别 等 于 客体 的 密级 时 ， 主 体 可 以 对 客 
体 进 行 如 下 操作 : 
A. 读 取 B:, 写 大 
C. 不 可 操作 D. 读 取 、 写 入 
【答案 : D】 
二 、 填 空 题 


站 


计算 机 系统 存在 ”技术 安全 、_ 管理 安全 和 政策 法 律 _ 三 类 安全 性 问题 。 
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2. TCSEC/TDI 标准 由 _ 安全 策略 、_ 责任 、_ 保证 和 文档 四 个 方面 
构成 。 

3. 保护 数据 安全 性 的 一 般 方法 是 设置 用 户 标识 和 _ 存 取 权 限 控制 

4. 安全 性 控制 的 一 般 方法 有 _ 用 户 标识 鉴定 、_ 存 取 控 制 、 审计 、 数据 加 密 和 视 
图 的 保护 五 级 安全 措施 。 

5. 存 取 权 限 包括 两 方面 的 内 容 , 一 个 是 要 存 取 的 数据 对 象 ”， 另 一 个 是 _ 对 此 数 
对 象 进行 操作 的 类 型 

6. 在 数据 库 系统 中 对 存 取 权 限 的 定义 称 为 _ 授权 _。 

7. 在 SQL 语言 中 ,为 了 数据 库 的 安全 性 ， 设 置 了 对 数据 的 存 取 进行 控制 的 语句 ， 对 
户 授权 使 用 _GRANT 语句 ， 收 回 所 授 的 权限 使 用 _REVOKE 语句 。 

8. DBMS 存 取 控制 机 制 主要 包括 两 类 : 自主 存 取 控制 和 强制 存 取 控 制 _。 

9.， 用 户 权限 由 _ 数据 对 象 “ 和 _ 操作 类 型 _ 两 部 分 构成 。 

10. 当 对 某 一 表 进 行 诸如 _INSERT 、DELETE 、UPDATE 这 些 操作 时 , SQL Server 
会 自动 执行 触发 器 所 定义 的 SQL 语句 。 

三 、 问 答题 

1. 数据 库 安全 性 控制 的 常用 方法 有 哪些 ? 

答 : 数据 库 安全 性 控制 的 常用 方法 如 下 。 

(1) 用 户 标识 和 鉴定 : 是 数据 库 访问 控制 的 最 外 层 安全 保护 措施 ， 通 过 用 户 标 识 和 口 

(2) 存 取 控制 :通过 用 户 权 限定 义 和 合 法 权限 检查 机 制 共同 构成 DBMS 的 安全 子 系统 。 

(3) 视图 : 可 在 一 定 程度 上 对 保密 数据 提供 隐藏 保护 。 

(4) 审计 : 用 于 记录 用 户 对 数据 库 的 所 有 操作 ， 以 便 事后 跟踪 和 追溯 。 

(5) 加 密 存储 : 对 高 度 机 密 的 数据 进行 数据 加 密 ， 是 防止 数据 在 存储 和 传输 过 程 中 失 
密 的 有 效 手段 。 

2. 写 出 下 列 SQL 自主 权限 控制 命令 。 

(1) 把 对 Student 和 Course 表 的 全 部 权限 授予 所 有 用 户 。 

GRANTALL PRIVILIGES ON TABLE Student, Course TO PUBLIC; 

(2) 把 对 Student 表 的 查询 权 和 姓名 修改 权 授 予 用 户 U4。 

GRANT SELECT UPDATE(Sname) ON TABLE Student TO U4; 


(3) 把 对 SC 表 的 插入 权限 授予 U5 用 户 ， 并 允许 他 传播 该 权限 。 


GRANT INSERT ON TABLE SC TO U5 WIIH GRANT OPTION: 


(4) 把 用 户 US 对 SC 表 的 INSERT 权限 收回 ， 同 时 收回 被 他 传播 出 去 的 授权 。 
REVOKE INSERT ON TABLE SC FROM US CASCADE: 


(5) 创建 一 个 角色 R1， 并 使 其 对 Student 表 具 有 数据 查询 和 更 新 权限 。 


内 容 
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会 自动 执行 触发 器 所 定义 的 SQL 语句 。 

三 、 问 答题 

1. 数据 库 安全 性 控制 的 常用 方法 有 哪些 ? 

答 : 数据 库 安全 性 控制 的 常用 方法 如 下 。 

(1) 用 户 标识 和 鉴定 : 是 数据 库 访问 控制 的 最 外 层 安全 保护 措施 ， 通 过 用 户 标 识 和 口 

(2) 存 取 控制 :通过 用 户 权 限定 义 和 合 法 权限 检查 机 制 共同 构成 DBMS 的 安全 子 系统 。 

(3) 视图 : 可 在 一 定 程度 上 对 保密 数据 提供 隐藏 保护 。 

(4) 审计 : 用 于 记录 用 户 对 数据 库 的 所 有 操作 ， 以 便 事后 跟踪 和 追溯 。 
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2. 写 出 下 列 SQL 自主 权限 控制 命令 。 

(1) 把 对 Student 和 Course 表 的 全 部 权限 授予 所 有 用 户 。 

GRANTALL PRIVILIGES ON TABLE Student, Course TO PUBLIC; 

(2) 把 对 Student 表 的 查询 权 和 姓名 修改 权 授 予 用 户 U4。 

GRANT SELECT UPDATE(Sname) ON TABLE Student TO U4; 


(3) 把 对 SC 表 的 插入 权限 授予 U5 用 户 ， 并 允许 他 传播 该 权限 。 


GRANT INSERT ON TABLE SC TO U5 WIIH GRANT OPTION: 


(4) 把 用 户 US 对 SC 表 的 INSERT 权限 收回 ， 同 时 收回 被 他 传播 出 去 的 授权 。 
REVOKE INSERT ON TABLE SC FROM US CASCADE: 


(5) 创建 一 个 角色 R1， 并 使 其 对 Student 表 具 有 数据 查询 和 更 新 权限 。 


内 容 
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(4) 审计 : 用 于 记录 用 户 对 数据 库 的 所 有 操作 ， 以 便 事后 跟踪 和 追溯 。 

(5) 加 密 存储 : 对 高 度 机 密 的 数据 进行 数据 加 密 ， 是 防止 数据 在 存储 和 传输 过 程 中 失 
密 的 有 效 手段 。 

2. 写 出 下 列 SQL 自主 权限 控制 命令 。 

(1) 把 对 Student 和 Course 表 的 全 部 权限 授予 所 有 用 户 。 

GRANTALL PRIVILIGES ON TABLE Student, Course TO PUBLIC; 

(2) 把 对 Student 表 的 查询 权 和 姓名 修改 权 授 予 用 户 U4。 

GRANT SELECT UPDATE(Sname) ON TABLE Student TO U4; 


(3) 把 对 SC 表 的 插入 权限 授予 U5 用 户 ， 并 允许 他 传播 该 权限 。 


GRANT INSERT ON TABLE SC TO U5 WIIH GRANT OPTION: 


(4) 把 用 户 US 对 SC 表 的 INSERT 权限 收回 ， 同 时 收回 被 他 传播 出 去 的 授权 。 
REVOKE INSERT ON TABLE SC FROM US CASCADE: 


(5) 创建 一 个 角色 R1， 并 使 其 对 Student 表 具 有 数据 查询 和 更 新 权限 。 


内 容 
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CREATE ROLE R1; 
GRANT SELECT UPDATE ON TABLE StudentTO R1: 
(6) 对 修改 Student 表 结 构 的 操作 进行 审计 。 


AUDIT ALTER ON Student: 


第 五 章 数据 库 完整 性 





一 、 选 择 题 
1. 在 数据 库 系统 中 ， 保 证 数据 及 语义 正确 和 有 效 的 功能 是 5 
A. 并 发 控制 B. 存 取 控 制 C. 安全 控制 D. 完整 性 控制 
【答案 : D】 
2. 关于 主键 约束 以 下 说 法 错误 的 是 


A. 一 个 表 中 只 能 设置 一 个 主键 约束 
B. 允许 空 值 的 字段 上 不 能 定义 主键 约束 





C. 允许 空 值 的 字段 上 可 以 定义 主键 约束 
D. 可 以 将 包含 多 个 字段 的 字段 组 合 设置 为 主键 
【答案 : C】 
3. 在 表 或 视图 上 执行 除了 以 外 的 语句 都 可 以 激活 触发 器 。 
A.INSERT B.DELETE C. UPDATE D. CREATE 
【答案 : D】 
4. 数据 库 的 是 指数 据 的 正确 性 和 相 容 性 。 
A. 安全 性 B. 完整 性 C. 并 发 控制 D. 恢复 
【答案 : B】 
5. 在 数据 库 的 表 定义 中 , 限制 成 绩 属性 列 的 取 值 在 0~100 的 范围 内 , 属于 数据 
的 _ 约束 。 
A. 实体 完整 性 B. 参照 完整 性 。 C. 用 户 自 定义 ” D. 用 户 操作 
【答案 : C】 
6. 下 列 说 法 正确 的 是 5 


A. 使 用 ALTER TABLE ADD CONSTRAINT 可 以 增加 基于 元 组 的 约束 
B. 如 果 属 性 A 上 定义 了 UNIQUE 约束 ， 则 A 不 可 以 为 空 
C. 如 果 属 性 A 上 定义 了 外 码 约束 ， 则 A 不 可 以 为 空 
D. 不 能 使 用 ALTER TABLE ADD CONSTRAINT 增加 主 码 约束 
【答案 : A】 
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二 、 填 空 题 


“21s 


1. 数据 库 的 完整 性 是 指数 据 的 _ 实 体 完整 性 、 参 照 完整 性 和 用 户 自 定义 完整 性 








2. 实体 完整 性 是 指 在 基本 表 中 ，_ 主 属性 唯一 且 所 有 主 码 属性 不 能 取 空 值 _。 
3. 参照 完整 性 是 指 在 基本 表 中 ，_ 外 码 是 另 一 个 关系 主 码 的 有 效 值 或 是 空 值 。 
4. 为 了 保护 数据 库 的 实体 完整 性 ， 当 用 户 程序 对 主 码 进行 更 新 使 主 码 值 不 唯一 

















DBMS 就 _ 拒绝 此 操作 _。 





时 ， 


5. 在 CREATE TABLE 时 ,用户 定义 的 完整 性 约束 可 以 通过 NOTNULL 、_UNIQUE 


和 _CHECK_ 等 子 句 实现 。 


6. 定义 数据 库 完整 性 一 般 是 由 SQL 的 _ DDL _ 语句 实现 的 。 


三 、 设 计 题 


在 学 生 课程 管理 数据 库 中 创建 一 个 触发 器 ， 当 向 学 生 选 课表 插入 记录 时 ， 检 查 该 记录 


的 学 号 在 学 生 表 中 是 否 存 在 ， 检 查 该 记录 的 课程 号 在 课程 表 中 是 否 
否 在 0~100 范围 内 ， 若 有 一 项 为 否 ， 则 不 允许 插入 。 
【解答 】 


CREATE TRIGGER stu ins_tri 

ON sc 

FOR INSERT 

AS 

BEGIN 

DECLARE @s# CHAR(6),@c# CHAR(5),@grade INT 
SELECT @s#=sno,@c#=cno,@grade=score 
FROM INSERTED 

IF (@s# not in(select sno from student)) OR 
(@c# not in (select cno from course) )OR 
(@grade not between 0 and 100) 
ROLLBACK TRANSACTION 

ELSE 

PRINT "成 功 插入 ' 

END 


1. 简 述 可 能 破坏 参照 完整 性 的 情况 及 违约 处 理 方式 。 
答 : 可 能 破坏 参照 完整 性 的 情况 及 违约 处 理 方式 如 下 表 所 示 。 


存在 ， 以 及 选课 成 


志 且 . 
绩 是 











被 参照 表 ( 例 如 student) 违约 处 理 
可 能 破坏 参照 完整 性 拒绝 
可 能 破坏 参照 完整 性 拒绝 
删除 元 组 拒绝 /级 连 删除 /设置 为 空 值 
修改 主 码 值 拒绝 /级 连 删除 /设置 为 空 值 
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(1) 在 参照 表 中 插入 或 删除 元 组 时 可 能 会 破坏 参照 完整 性 ，DBMS 将 拒绝 执行 。 

(2) 在 被 参照 表 中 删除 元 组 时 也 可 能 会 破坏 参照 完整 性 ，DBMS 将 选择 拒绝 删除 、 级 
连 删 除 、 设 置 为 空 值 几 种 方案 处 理 ， 拒 绝 为 默认 策略 。 

(3) 在 被 参照 表 中 修改 主 码 值 时 也 可 能 会 破坏 参照 完整 性 ，DBMS 将 选择 拒绝 修改 、 
级 连 修改 、 设 置 为 空 值 几 种 方案 处 理 ， 拒 绝 为 默认 策略 。 


第 六 章 关系 数据 理论 














一 、 选 择 题 
1. 关系 规范 化 中 的 删除 操作 异常 是 指 _ ”(D __， 插入 操作 异常 是 指 ” ®® _。 
A. 不 该 删除 的 数据 被 删除 B. 不 该 插入 的 数据 被 插入 
C. 应 该 删除 的 数据 未 被 删除 D. 应 该 插入 的 数据 未 被 插入 
【答案 : OA @D】 
2. 设计 性 能 较 优 的 关系 模式 称 为 规范 化 ， 规 范 化 主要 的 理论 依据 是 
A. 关系 规范 化 理论 B. 关系 运算 理论 
C. 关系 代数 理论 D. 数理 逻辑 
【答案 : A】 
3. 规范 化 过 程 主要 为 克服 数据 库 罗 辑 结构 中 的 插入 异常 、 删 除 异 常 及 的 缺陷 。 
A. 数据 的 不 一 致 性 B. 结构 不 合理 
C. 元 余 度 大 D. 数据 丢失 
【答案 : C】 
4. 当 关 系 模式 R(A, B) 已 属于 3NF， 下 列 说 法 中 是 正确 的 。 
A. 它 一 定 消除 了 插入 和 删除 异常 B. 仍 存在 一 定 的 插入 和 删除 异常 
C. 一 定 属于 BCNF D.A 和 C 都 是 
【答案 : B】 
5. 关系 模型 中 的 关系 模式 至 少 是 
A. INF B. 2NF C.3NF D. BCNF 
【答案 : A】 
6. 在 关系 DB 中 ， 任 何 二 元 关系 模式 的 最 高 范式 必定 是 
A. INF B. 2NF C.3NF D. BCNF 
【答案 : D】 
7. 在 关系 模式 R 中 ， 若 其 函数 依赖 集中 所 有 候选 关键 字 都 是 决定 因素 ， 则 R 最 高 范 
式 是 2 
A.2NF B. 3NF C.4NF D. BCNF 
【答案 : C】 


8. 候选 关键 字 中 的 属性 称 为 





中 称 


过 
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A. 非 主 属性 B. 主 属性 C. 复合 属性 D. 关键 属性 
【答案 : B】 
9. 消除 了 部 分 函数 依赖 的 INF 的 关系 模式 ， 必 定 是 & 
A. INF B. 2NF C.3NF D. 4NF 
【答案 : B】 
10. 关系 模式 的 候选 关键 字 可 以 有 _ 四， 主 关键 字 有 _®@® _。 
A.0 个 B.1 个 C. 1 个 或 多 个 D. 多 个 


【答案 : DC @B】 
11. 根据 关系 数据 库 规范 化 理论 ， 关 系数 据 库 中 的 关系 要 满足 第 一 范式 。 下 面 “ 部 门 ” 











中 ， 因 哪个 属性 而 使 它 不 满足 第 一 范式 ? 
部 门 (部 门 号 ， 部 门 名 ， 部 门 成 员 ， 部 门 总 经 理 ) 
A. 部 门 总 经 理 B. 部 门 成 员 C. 部 门 名 D. 部 门 号 
【答案 : B】 
12. 在 关系 模式 中 ， 如 果 属 性 A 和 B 存在 1 对 1 的 联系 ， 则 说 。 
A.A=B B. B 一 A CA 一 一 B D. 以 上 都 不 是 
【答案 : C】 
13. 关系 模式 R 中 的 属性 全 部 是 主 属性 ， 则 R 的 最 高 范式 必定 是 
A.2NF B. 3NF C. BCNF D. 4NF 
【答案 : B】 
14. 关系 数据 库 规范 化 是 为 了 解决 关系 数据 库 中 问题 而 引出 的 。 
A. 插入 、 删 除 和 数据 元 余 B. 提高 查询 速度 
C. 减少 数据 操作 的 反复 性 D. 保证 数据 完整 性 和 安全 性 
【答案 : A】 
二 、 填 空 题 


1. 在 关系 A(S, SN, D) 和 B(D, CN, NM) 中 ，A 的 主键 是 S，B 的 主键 是 D,， 则 D 在 S 

为 ”外 码 。 

2. 对 于 非 规范 化 的 模式 ， 经 过 ”使 属性 域 变 为 简单 域 转变 为 INF,， 将 1NF 经 
消除 非 主 属性 对 主 码 的 部 分 依赖 “转变 为 2NF， 将 2NF 经 过 ”消除 非 主 属性 对 











主 码 的 传递 依赖 “转变 为 3NF。 


有 的 


3. 在 关系 数据 库 的 规范 化 理论 中 ， 在 执行 “分 解 ” 时 ， 必 须 遵守 规范 化 原则 : 保持 原 





分 析 大 


问题 


三 、 解 答题 


1. 已 知 关系 模式 Student<U、F>，U={ 学 号 ， 所 属 系 ， 系 主任 ， 课 程 号 ， 成 绩 }， 
属性 间 的 函数 依赖 了 ,然后 将 其 分 解 为 更 高 级 的 范式 以 解决 数据 操作 异常 和 宛 余 
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【解答 】 

函数 依赖 : F = {学 号 一 所 属 系 , 所 属 系 一 系 主任 ，( 学 号 ,课程 号 ) 一 成 绩 } 

模式 分 解 : 

S( 学 号 ， 所 属 系 ， 学 号 一 所 属 系 ) 

SC( 学 号 ， 课 程 号 ， 成 绩 ，( 学 号 ， 课 程 号 ) 一 成 绩 ) 

DEPT( 所 属 系 ， 系 主任 ， 所 属 系 一 系 主任 ) 

2. 考虑 关系 模式 R(A.B,C,D)， 写 出 满足 下 列 函 数 依 赖 时 R 的 码 ， 并 给 出 R 属于 哪 种 

(1) B—D,AB—C; 

(2) A—B.,A—CD—A:; 

(3) BCD—A,A—C; 

(4) B 一 C.B 一 D.CD 一 A; 

(5) ABD 一 C。 

【解答 】 

(1) R 的 码 为 AB; RE 1NF。 

(2) R 的 码 为 D; RE2NF。 

(3) R 的 码 为 BCD、ABD; RE3NF。 

(4) R 的 码 为 B; RE2NF。 

(5) R 的 码 为 ABD; REBCNF。 

3. 已 知 学 生 关 系 模式 S(Sno,Sname.,SD,Sdname,Course,Grade), 其 中 : Sno 为 学 号 , Sname 
为 姓名 ，SD 为 系 名 ，Sdname 为 系 主任 名 ，Course 为 课程 ，Grade 成 绩 。 

(1) 写 出 关系 模式 S 的 基本 函数 依赖 和 主 码 。 

(2) 原 关系 模式 S 为 几 范 式 ? 为 什么 ? 分 解 成 高 一 级 范式 ， 并 说 明 为 什么 。 

(3) 将 关系 模式 分 解 成 3NF， 并 说 明 为 什么 。 

【解答 】 

(1) 关系 模式 S 的 基本 函数 依赖 如 下 : 

Sno—Sname, SD—Sdname, Sno—™SD, (Sno,Course) 一 Grade 

关系 模式 S 的 码 为 (Sno, Course)。 

(2) 原 关系 模式 S 是 属于 1NF 的 , 码 为 (Sno,Course), 非 主 属性 中 的 成 绩 完全 依赖 于 码 ， 
而 其 他 非 主 属性 对 码 的 函数 依赖 为 部 分 函数 依赖 ， 所 以 不 属于 2NF。 

消除 非 主 属性 对 码 的 函数 依赖 为 部 分 函数 依赖 ， 将 关系 模式 分 解 成 2NF 如 下 : 

Sl(Sno, Sname, SD, Sdname) 

S2(Sno, Course, Grade) 

(3) 将 上 述 关 系 模式 分 解 成 3NF 如 下 : 

关系 模式 S1 中 存在 Sno 一 SD，SD 一 Sdname， 即 非 主 属性 Sdname 传递 依赖 于 Sno， 
所 以 S1 不 是 3NF。 进 一 步 分 解 如 下 : 

S11(Sno, Sname.SD) S12(SD. Sdname) 
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分 解 后 的 关系 模式 S11、S12 满足 3NF。 

对 关系 模式 S2 不 存在 非 主 属性 对 码 的 传递 依赖 ， 故 属于 3NF。 所 以 ， 原 模式 S(Sno, 
Sname, SD, Sdname, Course, Grade) 按 如 下 分 解 满足 3NF。 

S11(Sno. Sname, SD) 




















S12(SD. Sdname) 

S2(Sno, Course, Grade) 

4. 设 有 如 下 表 关 系 及 

课程 名 教师 名 教师 地 址 

Cl 马 千 里 D1 
C2 于 得 水 D1 
C3 金 灶 沐 D2 
C4 于 得 水 D1 





(1) 它 为 第 几 范式 ? 为 什么 ? 

(2) 是 否 存在 删除 操作 异常 ? 若 存在 ， 则 说 明 是 在 什么 情况 下 发 生 的 。 

(3) 将 它 分 解 为 高 一 级 范式 ， 分 解 后 的 关系 是 如 何 解决 分 解 前 可 能 存在 的 删除 操作 异 
常 问题 ? 

【解答 】 

(1) RE2NF。 因 为 R 的 候选 码 为 “课程 名 ”依赖 关系 : 课程 名 一 教师 名 ， 教 师 名 一 
教师 地 址 ， 所 以 ， 课 程 名 一 教师 地 址 。 即 存在 非 主 属性 “教师 地 址 ”对 候选 码 “课程 名 ” 
存在 传递 函数 依赖 ， 因 此 及 不 是 3NF。 但 又 不 存在 非 主 属性 对 候选 码 的 部 分 函数 依赖 ， 所 
以 RE2NF。 

(2) 存在 。 当 删除 某 门 课 程 时 会 删除 不 该 删除 的 教师 的 有 关 信 息 ( 教 师 地 址 )。 

(3) 分 解 为 高 一 级 范式 如 下 图 所 示 。 

及 1 


教师 地 址 


























分 解 后 , 若 删除 课程 数据 时 , 仅 对 关系 R1 操作 , 教师 地 址 信息 在 关系 R2 中 仍然 保留 ， 
不 会 丢失 教师 方面 的 信息 。 
5. 设 某 商业 集团 数据 库 中 有 一 关系 模式 R 如 下 : R( 商 店 编号 ， 商 品 编号 ， 数 量 ， 部 门 
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编号 ， 负 责 人 )。 如 果 规定 : 每 个 商店 的 每 种 商品 只 在 一 个 部 门 销售 ，@ 每 个 商店 的 每 个 
部 门 只 有 一 个 负责 人 ; @@ 每 个 商店 的 每 种 商品 只 有 一 个 库存 数量 。 

试 回答 下 列 问题 : 

(1) 根据 上 述 规定 ， 写 出 关系 模式 R 的 基本 函数 依赖 。 

(2) 找 出 关系 模式 R 的 候选 码 。 

(3) 试问 关系 模式 R 最 高 已 经 达到 第 几 范 式 ? 为 什么 ? 

(4) 如 果 RR 不 属于 3NF， 请 将 分解 成 3NF 模式 集 。 

【解答 】 

(1) 关系 模式 S 的 基本 函数 依赖 如 下 : (商店 编号 ， 商 品 编号 ) 一 部 门 编号 ，( 商 店 编号 ， 
部 门 编号 ) 一 负责 人 ，( 商 店 编号 ， 商 品 编号 ) 一 数量 

(2) 关系 模式 R 的 码 为 (商店 编号 ， 商 品 编号 ， 部 门 编号 )。 

(3) 原 关 系 模式 R 属于 INF， 码 为 (商店 编号 ， 商 品 编号 ,部门 编号 )， 非 主 属性 对 码 的 
函数 依赖 全 为 部 分 函数 依赖 ， 所 以 不 属于 2NF。 

消除 非 主 属性 对 码 的 函数 依赖 为 部 分 函数 依赖 ， 将 关系 模式 分 解 成 2NF 如 下 : 

R1( 商 店 编号 ， 商 品 编号 ,部门 编号 , 数量 ); 

R2( 商 店 编号 ， 部 门 编号 , 负责 人 )。 

(4) 将 RR 分 解 为 : 

R1( 商 店 编号 ， 商 品 编号 ,部门 编 号 , 数量); 

R2( 商 店 编号 ， 部 门 编号 , 负责 人 )。 

分 解 后 的 及 不 存在 传递 的 函数 依赖 ， 所 以 分 解 后 的 及 已 经 是 3NF。 


第 七 章 ”数据 库 设计 





一 、 选 择 题 
1. 在 数据 库 设 计 中 , 用 E-R 图 来 描述 信息 结构 但 不 涉及 信息 在 计算 机 中 的 表示 , 它 是 
数据 库 设 计 的 阶段 。 
A. 需求 分 析 B. 概念 设计 C. 逻辑 设计 D. 物理 设计 
【答案 : B】 
2. 在 关系 数据 库 设 计 中 ， 设 计 关系 模式 是 的 任务 。 
A. 需求 分 析 阶 段 ”B. 概念 设计 阶段 C. 逻辑 设计 阶段 D. 物理 设计 阶段 
【答案 ; C】 


3. 数据 库 物理 设计 完成 后 ， 进 入 数据 库 实 施 阶段 ， 下 列 各 项 中 不 属于 实施 阶段 的 工作 
A. 建立 库 结构 B. 扩充 功能 C. 加 载 数据 D. 系统 调试 

【答案 : B】 

4. 在 数据 库 的 概念 设计 中 ， 最 常用 的 数据 模型 是 5 
A. 形象 模型 B. 物理 模型 C. 逻辑 模型 D. 实体 联系 模型 


Hu 
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【答案 : D】 
5. 从 E-R 模型 关系 向 关系 模型 转换 时 ， 一 个 M : N 联系 转换 为 关系 模型 时 ， 该 关系 
模式 的 关键 字 是 
A. M 端 实体 的 关键 字 
B. N 端 实体 的 关键 字 
C. M 端 实 体 关键 字 与 N 端 实体 关键 字 组 合 
D. 重新 选取 其 他 属性 


【答案 : C】 

6. 当局 部 E-R 图 合并 成 全 局 E-R 图 时 可 能 出 现 冲突 ， 不 属于 合并 冲突 的 是 yg 
A. 属性 冲突 B. 语法 冲突 C. 结构 冲突 D. 命名 冲突 

【答案 : 】B 

7. 概念 模型 独立 于 
A. E-R 模型 B. 硬件 设备 和 DBMS 
C. 操作 系统 和 DBMS D. DBMS 

【答案 : 】B 

8. 数据 流程 图 (DFD) 是 用 于 描述 结构 化 方法 中 阶段 的 工具 。 





A. 可 行 性 分 析 B. 详细 设计 C. 需求 分 析 D. 程序 编码 
【答案 : C】 





9. 下 图 所 示 的 E-R 图 转换 成 关系 模型 ， 可 以 转换 为 关系 模式 。 
A.1 个 BE2 C3 D.4 个 
【答案 : C】 








1. 设计 数据 库 必须 遵循 _ 结 构 设 计 _ 和 行为 设计 _ 相 结合 的 原则 。 

2. “为 哪些 表 ， 在 哪些 字段 上 ， 建 立 什 么 样 的 索引 ”这 一 设计 内 容 应 该 属于 数据 库 
物理 _ 设 计 阶 段 。 

3. 在 数据 库 设 计 中 ， 把 数据 需求 写成 文档 ， 它 是 各 类 数据 描述 的 集合 ， 包 括 数据 项 、 
数据 结构 、 数 据 流 、 数 据 存储 和 数据 加 工 过 程 等 的 描述 ， 通 常 称 为 。 数据 字典 。 

4. 在 设计 局 部 E-R 图 时 ,由 于 各 个 子 系统 分 别 有 不 同 的 应 用 , 而 且 往 往 是 由 不 同 的 设 
计 人 员 设计 的 ， 所 以 各 个 局 部 E-R 图 之 间 难 免 有 不 一 致 的 地 方 ， 这 些 冲 突 主要 有 _ 属性 
冲突 、 命名 冲突 和 ”结构 冲突 三 类 。 

5. 用 户 对 数据 库 的 要 求 包括 _ 信 息 要 求 、. 处 理 要 求 、_ 安 全 性 要 求 和 完整 性 要 求 
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四 个 方面 。 
6. 数据 字典 主要 包括 数据 项 、 数据 结构 、 数据 流 、 数据 存储 和 处 理 过 程 五 
个 部 分 。 








7. 三 种 常用 抽象 方法 是 分 类 、_ 聚 集 和 概括 。 
8. 数据 库 常 用 的 存 取 方 法 包括 _ 索 引 方法 、_ 聚 秘方 法 和 _HASH 方法 三 种 。 
9. 确定 数据 存放 位 置 和 存储 结构 需要 考虑 的 因素 主要 有 _ 存 取 时 间 _、._ 存储 空间 和 




















这 和 维护 代价 等 
10. 集成 局 部 E-R 图 要 分 两 个 步 又， 分别 是 _ 合 并 和 _ 修改 和 重 构 _。 
三 、 问 答题 
1. 简 述 数据 库 设计 步骤 及 各 部 分 的 作用 ? 
入 


(1) 需求 分 析 : 了 解 与 分 析 用 户 需求 ， 得 到 数据 字典 和 数据 流 图 。 

(2) 概念 结构 设计 阶段 在 需求 分 析 的 基础 上 ， 选 择 设计 出 一 个 独立 于 DBMS 的 概念 
模型 。 

(3) 池 辑 结构 设计 : 为 概念 结构 设计 阶段 的 概念 模型 选择 一 个 DBMS 的 数据 模型 。 

(4) 物理 结构 设计 : 为 数据 模型 选择 一 个 最 合适 的 物理 存储 结构 。 

(5) 数据 库 的 实施 : 设计 数据 库 ， 并 组 织 数据 入 库 、 编 制 调试 应 用 程序 ， 进 行 试 运行 。 

(6) 数据 库 的 运行 和 维护 : 在 此 阶段 进行 维护 数据 库 ， 保 证 数据 库 正 常 工作 ， 并 不 断 

2. 简 述 建立 索引 的 一 般 原 则 。 

答 ， 

(1) 如 果 一 个 (或 一 组 ) 属 性 经 常 在 查询 条 件 中 出 现 ， 则 考虑 在 这 个 (或 这 组 ) 属 性 上 建立 
索引 (或 组 合 索 引 )。 

(2) 如 果 一 个 属性 经 常 作为 最 大 值 和 最 小 值 等 聚集 函数 的 参数 ， 则 考虑 在 这 个 属性 建 
立 索 引 。 

(3) 如 果 一 个 (或 一 组 ) 属 性 经 常 在 连接 操作 的 连接 条 件 中 出 现 ， 则 考虑 在 这 个 (或 这 组 ) 
属性 上 建立 索引 。 

(4) 维护 和 查找 索引 需要 开销 ， 频 繁 增删 的 关系 不 宜 建 立 太 多 索引 。 

3. 数据 库 投 入 正式 运行 后 为 什么 还 需要 维护 ? 维护 工作 由 谁 负责 ? 主要 工作 有 哪些 ? 

2 

数据 库 维护 的 原因 主要 如 下 : @ 应 用 环境 在 不 断 变化 ，@ 物 理 存储 会 不 断 变化 。 

数据 库 的 日 常 维护 工作 主要 由 DBA 负责 ， 主 要 工作 如 下 : 

(1) 数据 库 的 转 储 和 恢复 ; 

(2) 数据 库 的 安全 性 、 完 整 性 控制 ; 

(3) 数据 库 性 能 的 监督 、 分 析 和 改进 ; 

(4) 数据 库 的 重组 织 和 重 构造 。 
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四 、 综 合 题 

1. 假设 教学 管理 规定 : 

@ 一 个 学 生 可 选修 多 门 课 ， 一 门 课 有 若干 学 生 选 修 ; 

@ 一 个 教师 可 讲授 多 门 课 ， 一 门 课 只 有 一 个 教师 讲授 ; 

@ 一 个 学 生 选 修一 门 课 ， 仅 有 一 个 成 绩 。 

学 生 的 属性 有 学 号 、 学 生 姓 名 ; 教师 的 属性 有 教师 编号 、 教 师 姓名 课程 的 属性 有 课 
程 号 、 课 程 名 。 

要 求 : 根据 上 述 语义 画 出 E-R 图 ， 要 求 在 图 中 画 出 实体 的 属性 ， 并 注 明 联系 的 类 型 。 

【解答 】 











2. 设 有 如 下 实体 。 

学 生 : 学 号 、 单 位 、 姓 名 、 性 别 、 年 龄 、 选 修 课程 名 。 

课程 : 编号 、 课 程 名 、 开 课 单 位 、 任 课 教 师 号 。 

教师 : 教师 号 、 姓 名 、 性 别 、 职 称 、 讲 授课 程 编 号 。 

单位 : 单位 名 称 、 电 话 、 教 师 号 、 教 师 名 。 

上 述 实体 中 存在 如 下 联系 : 

(1) 一 个 学 生 可 选修 多 门 课程 ， 一 门 课程 可 为 多 个 学 生 选 修 ; 
(2) 一 个 教师 可 讲授 多 门 课程 ， 一 门 课程 可 为 多 个 教师 讲授 ; 
(3) 一 个 单位 可 有 多 个 教师 ， 一 个 教师 只 能 属于 一 个 单位 。 
完成 如 下 工作 : 

(1) 分 别 设计 学 生 选课 和 教师 任课 两 个 局 部 信息 的 结构 E-R 图 。 
(2) 将 上 述 设 计 完 成 的 E-R 图 合并 成 一 个 全 局 E-R 图 。 

(3) 将 该 全 局 E-R 图 转换 为 等 价 的 关系 模型 表示 的 数据 库 罗 辑 结构 。 
【解答 】 

(1) 学 生 选 课 局 部 E-R 图 。 
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为 避免 图 形 复杂 ， 下 面 给 出 各 实体 属性 。 
单位 : 单位 名 、 电 话 。 

学 生 : 学 号 、 姓 名 、 性 别 、 年 龄 。 

教师 : 教师 号 、 姓 名 、 性 别 、 职 称 。 

课程 : 编号 、 课 程 号 。 

(3) 该 全 局 E-R 图 转换 为 等 价 的 关系 模型 表示 的 数据 库 罗 辑 结构 如 下 : 
单位 (单位 名 ， 电 话 ); 

教师 (教师 号 ， 姓 名 ， 性 别 ， 职 称 ， 单 位 名 ); 
课程 (课程 编号 ， 课 程 名 ， 单 位 名 ); 
学 生 (学 号 ， 姓 名 ， 性 别 ， 年 龄 ， 单 位 名 ); 
讲授 (教师 号 ， 课 程 编号 ); 

选修 (学 号 ， 课 程 编号 )。 
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模拟 试题 (一 ) 


一 、 填 空 题 ( 共 10 分 ， 每 空 1 分 ) 








1. 从 数据 库 管理 系统 的 角度 划分 数据 库 系 统 的 体系 结构 , 可 分 为 、 和 
3 层 。 

2. RDBMS 的 中 文 意思 是 。 

3. 在 关系 代数 中 ， 8 连接 是 由 稍 卡 尔 积 和 运算 组 合 而 成 的 。 


4. 通过 模式 分 解 把 属于 低级 范式 的 关系 模式 转换 为 几 个 属于 高 级 范式 的 关系 模式 的 
集合 ， 这 一 过 程 称 为 





5. 要 使 关系 模式 属于 第 三 范式 ， 既 要 消除 ， 也 要 消除 
6. 利用 游标 进行 查询 需要 4 种 语句 ， 分 别 是 说 明 游标 、 、 和 关闭 
游标 。 


二 、 单 选 题 ( 共 10 分 ， 每 题 1 分 ) 
1. 数据 库 系 统 的 基础 是 

A. 数据 结构 B. 数据 库 管 理 系统 。 C. 操作 系统 D. 数据 模型 
2. 经 过 投影 运算 后 ， 所 得 关系 的 元 组 数 原 关系 的 元 组 数 。 

A. 等 于 B. 小 于 C. 小 于 或 等 于 ”D. 大 于 
3. 关系 及 与 关系 S 只 有 1 个 公共 属性 ，T1 是 及 与 S 作 9 连接 的 结果 ，T2 是 及 与 S 

作 自 然 连接 的 结果 ， 则 2 

A.TI1 的 属性 个 数 等 于 T2 的 属性 个 数 

B.TI1 的 属性 个 数 小 于 T2 的 属性 个 数 

C.T1 的 属性 个 数 大 于 或 等 于 T2 的 属性 个 数 

D.TI1 的 属性 个 数 大 于 T2 的 属性 个 数 
4. 在 SQL 中 ， 与 关系 代数 中 的 投影 运算 对 应 的 子 句 是 。 

A. SELECT B.FROM C. WHERE D. ORDER BY 
5. 在 SQL 的 排序 子 句 ， ORDER BY 总 分 DESC, 英语 DESC 表示 

A. 总 分 和 英语 分 数 都 是 最 高 的 在 前 面 

B. 总 分 和 英语 分 数 之 和 最 高 的 在 前 面 
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C. 总 分 高 的 在 前 面 ， 总 分 相同 时 英语 分 数 高 的 在 前 面 
D. 总 分 和 英语 分 数 之 和 最 高 的 在 前 面 ， 相 同时 英语 分 数 高 的 在 前 面 
6. 下 面 哪 一 个 依赖 是 平凡 依赖 : 
A. Sno Cname Grade 一 Sno Grade B. Sno Cname 一 Cname Grade 
C. Sno Cname— Sname Grade D. 以 上 答案 都 不 是 


7. 已 知 关系 尺 具 有 属性 A, B, C, D, E, F。 假设 该 关系 有 如 下 函数 依赖 : AB 一 C, BC 
一 AD, D 一 E, CF 一 B。 则 {A,B} 的 闭 包 是 
A. {A, B, C, D, E, F} B. {A, B, C} 
C. {A, B, C, D, E} D. {A, B} 
8. 一 个 关系 模式 R(x1, x2, x3, x4)， 假 定 该 关系 存在 如 下 函数 依赖 ，x1 一 x*2，x1 一 x3， 
x3 一 xX4， 则 该 关系 属于 和 
A.2NF B. 3NF C.4NF D. BCNF 
9. 保护 数据 库 中 的 信息 , 防止 未 经 授权 或 非法 的 使 用 所 造成 的 数据 泄漏 、 更 改 或 破坏 ， 
称 为 数据 库 的 
A. 安全 性 B. 完整 性 C. 恢复 D. 并 发 控制 
10. 有 两 个 变量 cno、cname 已 赋值 ， 对 应 关系 COURSE 中 字段 cno、cname。 则 将 
表 中 指定 cno 值 的 数据 对 应 的 cname 属性 值 改 变 为 新 指定 的 正确 的 嵌入 式 SQL 语句 格式 








A. EXEC SQL UPDATE COURSE SET (cname=:cname) WHERE cno=:cno: 
B. EXEC SQL UPDATE COURSE SET (cname=cname) WHERE cno=cno; 
C. EXEC SQL UPDATE COURSE SET (:cname=cname) WHERE :cno=cno; 
D. EXEC SQL UPDATE COURSE SET (:cname=:cname) WHERE :cno=:cno; 
三 、 判 断 题 ( 共 10 分 ， 每 题 1 分 ) 
1. 在 设计 基本 E-R 图 时 ， 必 须 消除 所 有 的 元 余数 据 和 宛 余 联系 。 ( 林 
2. 查询 优化 主要 是 物理 方法 的 优化 ， 而 逻辑 方法 优化 与 否 影响 不 大 。 (3 
3. 一 个 数据 库 可 以 建立 多 个 聚 徐 ， 但 一 个 关系 只 能 加 入 一 个 聚 徐 。 他 
4. 当 查 询 结 果 为 多 个 元 组 时 , 交互 式 SQL 中 采用 游标 机 制 来 指示 所 取出 元 组 的 位 置 。 
全 
5. 数据 库 重组 织 与 重 构造 的 差别 在 于 : 重组 织 并 不 修改 诛 有 的 逻辑 模 式 和 内 模式 ; 而 
重 构 造 会 部 分 修改 原 有 的 逻辑 模式 和 内 模式 。 ( ) 
6. 在 物理 设计 阶段 ， 根 据 DBMS 的 特点 和 处 理 需要 ， 选 择 存储 结构 ， 建 立 索 引 ， 形 
成 数据 库 的 模式 。 ( ) 
7. 邮 辑 设计 可 以 独立 于 数据 库 管理 系统 。 ( ) 
8. 若 并 发 事务 的 调度 是 可 串 行 化 的 ， 则 这 些 事务 一 定 都 遵守 两 段 锁 协 议 。 (  ) 
9. 事务 故障 的 恢复 是 由 系统 自动 完成 的 ， 对 用 户 是 透明 的 。 (人 


10. 一 个 一 对 多 联系 可 以 转换 为 一 个 独立 的 关系 模式 ， 也 可 以 与 1 端 对 应 的 关系 模式 
合并 。 ¢ 
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四 、 简 答题 ( 共 12 分 ， 每 题 4 分 ) 


1. 关系 模型 有 何 特点 ? 

2. 数据 库 系 统 中 可 能 发 生 的 故障 大 致 可 以 分 为 哪 几 类 ? 简 述 各 类 故障 的 恢复 机 制 。 

3. 简 述 画 E-R 图 时 区 别 实 体 与 属性 的 两 条 准则 是 什么 ? 

五 、 综 合 题 (第 1、2 题 10 分 , 第 3 题 18 分 , 第 4 题 28 分 ， 共 58 分 ) 

1. 假设 学 生 选 课 数 据 库 关系 模式 如 下 : 

STUDENT ( SNO, SNAME, SAGE, SDEPT); 

COURSE (CNO, CNAME):; 

SC (SNO, CNO, SCORE) 

(1) 用 SQL 语句 实现 如 下 查询 : 查询 学 生 张 林 的 “数据 库 原理 ”成 绩 。 

(2) 将 上 述 SQL 语句 转化 为 等 价 的 关系 代数 表达 式 。 

(3) 画 出 优化 后 的 查询 树 。 

2. 指出 下 列 关系 模式 是 第 几 范 式 ? 并 说 明理 由 。 

(1) REYZ) FF-{X~YX—Z} 

(2) R(A,B,C.D,E) F={AB—C,AB—E,A—D.BD—ACE} 

(3) R(WXYZ) F={X—Z,WX—Y} 

3. 一 个 车 间 有 多 个 工人 ， 每 个 工人 有 职工 号 、 姓 名 、 年 龄 、 性 别 、 工 种 ， 一 个 车 间 生 
产 多 种 产品 ， 产 品 有 产品 号 、 价 格 ; 一 个 车 间 生 产 多 种 零件 ， 一 种 零件 也 可 能 为 多 个 车 间 
制造 ， 零 件 有 零件 号 、 重 量 、 价 格 ; 一 种 产品 由 多 种 零件 组 成 ， 一 种 零件 也 可 装配 到 多 种 
产品 中 ， 产 品 与 零件 均 存 入 仓库 中 ; 厂 内 有 多 个 仓库 ， 仓 库 有 仓库 号 、 主 任 姓 名 、 电 话 。 

请 画 出 该 系统 的 E-R 图 ， 并 给 出 相应 的 关系 模型 ， 要 求 注 明 主 码 和 外 码 ， 其 中 主 码 用 
下 划 线 标 出 ， 外 码 用 波浪 线 标 出 。 

4. 有 关系 模式 如 下 : 

学 生 S(SNO, SN, SEX., AGE): 

课程 CCCNO, CN, PCNO)， 其 中 PCNO 为 直接 先行 课 ; 

选课 SC(SNO,CNO,G)， 其 中 G 为 课程 考试 成 绩 。 

(1) 用 关系 代数 及 SQL 语言 写 出 查询 语句 ， 查 询 所 有 学 生 都 选修 的 课程 名 CN。 

(2) 用 关系 代数 及 SQL 语言 写 出 查询 语句 , 查询 DB 课 成 绩 在 90 分 以 上 的 学 生 的 姓名 。 

(3) 将 选修 课程 DB 的 学 生 学 号 、 姓 名 建立 视图 SDB。 

(4) 在 学 生 选课 关系 SC 中 ， 把 英语 课 的 成 绩 提 高 10%。 
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模拟 试题 一 ) 


一 、 填 空 题 ( 共 10 分 ， 每 空 1 分 ) 


. 描述 事物 的 符号 记录 称 为 
. 如 果 D1 有 3 个 元 组 ，D2 中 有 4 个 元 组 ， 则 D1XD2 有 个 元 组 。 
. 在 SQL 语言 中 ,，“ ”和 符号 属于 通配符 。 
. 在 SQL 语言 中 ,“>ANY” 等 价 于 
是 从 一 个 或 几 个 基本 表 导 出 的 表 。 
. 触发 器 的 类 型 分 为 触发 器 和 语句 级 触发 器 。 
7. 在 MAC 机 制 当中 ， 仅 当主 体 的 许可 证 级 别 客体 的 密级 时 ， 该 主体 才能 读 
取 相 应 的 客体 。 
8. 对 于 关系 代数 的 查询 优化 ， 优化 策略 是 最 重要 和 最 基本 的 一 条 。 
9. 故障 系统 自动 执行 ， 介 质 故 障 需 要 DBA 的 介入 。 
10. DBMS 的 基本 工作 单位 是 事务 ， 它 是 用 户 定义 的 一 组 逻辑 一 致 的 程序 序列 ， 并 发 
控制 的 主要 方法 是 机 制 。 
二 、 单 选 题 ( 共 10 分 ， 每 题 1 分 ) 


1. 下 列 不 属于 数据 管理 技术 主要 经 历 阶 段 的 是 。 


QD- 














A. 手工 管理 B. 机 器 管理  C. 文件 系统 。 ”D. 数据 库 
2 数据库 的 概念 模型 独立 于 。 

A. 具体 的 机 器 和 DBMS B.E-R 图 

C. 信息 世界 D. 现实 世界 
3. 下 面 的 哪 种 范式 是 最 规范 的 数据 库 范 式 。 

A.2NF B. 3NF C.4NF D. BCNF 
4 下 列 不 属于 关系 完整 性 的 是 

A. 实体 完整 性 B. 参照 的 完整 性 

C. 用 户 定义 的 完整 性 D. 逻辑 结构 的 完整 性 


5. 不 同 的 数据 模型 是 提供 模型 化 数据 和 信息 的 不 同 工 具 ， 用 于 信息 世界 建 模 的 
A. 网 状 模型 B. 关系 模型 C. 概念 模型 D. 结构 模 
6. 下 列 关于 数据 库 系 统 正确 的 描述 是 3 
A. 数据 库 系统 减少 了 数据 的 元 余 
B. 数据 库 系 统 避 免 了 一 切 见 余 
C. 数据 库 系统 中 数据 的 一 致 性 是 指数 据 的 类 型 一 致 
D. 数据 库 系统 比 文件 系统 能 管理 更 多 的 数据 


并 
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7. 下 面 哪个 不 属于 数据 库 系统 的 三 级 模式 结构 : 

A. 外 模式 B. 模式 C. 中 模式 D. 内 模式 
8. 下 面 哪个 命令 属于 SQL 语言 授权 命令 : 

A. UPDATE B. DELETE C. SELECT D. GRANT 


9. 在 具有 监测 点 的 故障 恢复 技术 中 ， 下 面 哪个 事务 不 需要 REDO: 
B12 


A.Tl G3 D.T4 





理 系 统 故障 




















10. 同一 个 关系 模型 的 任意 两 个 元 组 值 。 


A. 不 能 全 同 B. 可 全 同 C. 必须 全 同 
三 、 简 答题 (每 题 5 分 ， 共 25 分 ) 
1. 简 述 数据 库 系统 的 三 级 模式 结构 和 两 级 映像 。 
2. 关系 的 完整 性 有 哪些 ? 并 用 实例 解释 。 
3. 实体 间 的 联系 有 哪些 ? 请 举例 说 明 。 
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D. 以 上 都 不 是 


. 数据 库 设计 分 为 哪儿 个 阶段 ? 
. 试 说 明 B+ 树 索 引 和 聚 簇 分 别 适合 用 在 什么 地 方 ? 
四 、 编 程 题 (每 小 题 1 分 ， 共 15 分 ) 


可 能 用 到 的 表 结构 如 下 : 

学 生 表 ( 学 号 ， 姓 名 ， 性 别 ， 年 龄 ， 班 级 ); 

课程 表 (课程 号 ， 课 程 名 ， 学 分 ); 

成 绩 表 (学 号 ， 课 程 号 ， 成 绩 )。 

1. 创建 存储 过 程 GetStudentByID， 带 有 参数 Sno， 根 据 学 生 的 学 号 查询 学 生 情况 。 

2. 编写 SQL 语句 ， 查 询 学 生 表 中 所 有 学 生 ， 要 求 首先 按照 班级 升序 排序 ， 然 后 按照 


年 龄 降序 排序 。 


3. 编写 SQL 语句 ， 查 询 学 生 表 中 姓 张 的 学 生 。 


4. 编写 SQL 语句 ， 
5. 编写 SQL 语句 ， 
6. 编写 SQL 语句 ， 
7. 编写 SQL 语句 ， 


查询 学 生 表 中 男女 4 


的 人 数 各 多 少 人 。 





查询 所 有 比 “ 王 平 ”年 龄 大 的 情况 。 
在 学 生 表 和 成 绩 表 中 查询 学 号 、 姓 名 、 课 程 号 、 成 绩 。 
将 (1022， 张 望 ， 男 ，19， 信 息 2) 的 学 生 插入 到 学 生 表 中 。 
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8. 编写 SQL 语句 ， 将 学 号 为 1022 学 生 的 姓名 改 为 张 旺 。 

9. 编写 SQL 语句 ， 删 除 没有 选课 的 学 生 。 

10. 编写 SQL 语句 ， 查 询 课程 号 9 的 选修 课 的 情况 。 

11. 编写 关系 代数 ， 查 询 选 修 3 号 课程 的 学 生 学 号 

12. 编写 关系 代数 ， 查 询 至 少 选修 了 一 门 直接 选修 课 为 5 号 课程 的 学 生 姓 名 。 
13. 编写 SQL 语句 ， 创 建 学 生 表 。 

14. 编写 SQL 语句 ， 建 立 计 算 机 1 班 男生 的 视图 。 

15. 编写 SQL 语句 ， 将 对 学 生 表 的 修改 权限 赋 给 用 户 Ul。 


五 、 求 解 题 ( 共 20 分 ) 


设 某 连锁 店 数据 库 系 统 中 有 三 个 实体 集 。 
hs 商店 号 、 商 店名 、 地 址 、 电 话 ; 
商品 : 商品 号 、 商 品名 、 单 价 ; 
职工 : 职工 号 、 职 工 名 。 
商店 与 商品 之 间 存 在 销售 联系 ， 其 属性 有 销售 日 期 和 销售 量 。 每 个 商店 可 以 销售 多 种 
商品 ， 每 种 商品 可 以 由 多 家 商店 销售 。 商 店 与 职工 之 间 存 在 聘任 联系 ， 属 性 有 工资 ， 每 个 
只 工 只 能 在 一 家 商店 工作 。 

(1) 试 画 出 E-R 图 。(4 分 ) 

(2) 将 E-R 模型 转换 为 关系 模型 。(4 分 ) 















































(3) 说 明 关系 模式 之 间 的 参照 关系 。(4 分 ) 
2. 有 如 下 关系 R、S， 求 RUS、RnS、R-S、RXS。(8 分 ) 
及 S: 
区 : 避 医 中 A|B | € 
al | bl | cl al | 二 
al | b2 | c2 al | bj | c2 
ea a2 |tb2| cl 
六 、 解 答题 ( 共 20 分 ) 
1. 有 如 下 表 所 示 的 关系 R: 
工程 号 完工 日 期 
Pl 0 9902 
Pl 体育 场 工 程 9902 
Pl 体育 场 工程 5 9902 
P2 教学 楼 工程 9912 





9912 
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(1) R 的 关键 字 是 什么 ? (3 分 ) 

(2) R 属于 第 几 范 式 ? 需要 证 明 。(5 分 ) 

(3) R 存在 的 问题 是 什么 ? (3 分 ) 

(4) 分 解 成 更 高 的 范式 。(3 分 ) 

2. 关系 模式 S( 学 生 ， 课 程 ， 名 次 )， 假 设 每 门 课 程 每 一 个 名 次 只 有 一 个 学 生 。 判断 该 
模式 是 第 几 范 式 ? 说 明理 由 。(6 分 ) 
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模拟 试题 三 ) 


、 填 空 题 ( 共 10 分 ， 每 空 1 分 ) 


1. 关系 数据 模型 由 关系 数据 结构 、 关 系 操作 和 三 部 分 组 成 。 
2. 一 般 情况 下 ， 当 对 关系 R 和 S 使 用 自然 连接 时 ， 要 求 R 和 S 含有 一 个 或 多 个 共有 








的 





3. 在 Student 表 的 Sname 列 上 建立 一 个 唯一 索引 的 SQL 语句 为 : 

CREATE Stusname ON student(Sname) 

4. SELECT 语句 查询 条 件 中 的 谓词 “!=ALL” 与 运算 符 ” _ 等 价 。 

5. 关系 模式 R(A, B, C, D) 中 ， 存 在 函数 依赖 关系 {A 一 B, A 一 C, A 一 D, (B, COC) 一 A}， 则 
候选 码 是 ，RE NF。 

6.E-R 图 之 间 的 冲突 主要 有 属性 冲突 、 、 结 构 冲 突 三 种 。 

7. 是 DBMS 的 基本 单位 ， 是 用 户 定义 的 一 个 数据 库 操 作 序列 。 

8. 存在 一 个 等 待 事务 集 {To，Ti，…，Tej， 其 中 To 正 等 待 被 Ti 锁 住 的 数据 项 ，T 正 
等 待 被 T 锁 住 的 数据 项 , Ta 正 等 待 被 To 锁 住 的 数据 项 , 且 Ta 正 等 待 被 To 锁 住 的 数据 项 ， 
这 种 情形 称 为 
9. _ 是 并 发 事务 正确 性 的 准则 。 

二 、 单 选 题 ( 共 40 分 ， 每 题 2 分 ) 


1. 数据 库 系统 的 核心 是 








A. 数据 库 B. 数据 库 管理 系统 
C. 数据 模型 D. 软件 工具 
2. 下 列 四 项 中 ， 不 属于 数据 库 系 统 的 特点 的 是 
A. 数据 结构 化 B. 数据 由 DBMS 统一 管理 和 控制 
C. 数据 元 余 度 大 D. 数据 独立 性 高 
3. 概念 模型 是 现实 世界 的 第 一 层 抽 象 ， 这 一 类 模型 中 最 著名 的 模型 是 
A. 层次 模型 B. 关系 模型 
C. 网 状 模型 D. 实体 -联系 模型 


4. 数据 的 物理 独立 性 是 指 5 
A. 数据 库 与 数据 库 管理 系统 相互 独立 
B. 用 户 程序 与 数据 库 管 理 系 统 相互 独立 
C. 用 户 的 应 用 程序 与 存储 在 磁盘 上 数据 库 中 的 数据 是 相互 独立 的 
D. 应 用 程序 与 数据 库 中 数据 的 逻辑 结构 是 相互 独立 的 
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5. 要 保证 数据 库 的 逻辑 数据 独立 性 ， 需 要 修改 的 是 
A. 模式 与 外 模式 之 间 的 映 象 B. 模式 与 内 模式 之 间 的 映 象 
C. 模式 D. 三 级 模式 

6. 关系 数据 模型 的 基本 数据 结构 是 S 
A. 树 B. 图 C. 索引 D. 关系 


7. 有 一 名 为 “列车 运营 ”实体 ， 含 有 车 次 、 日 期 、 实 际 发 车 时 间 、 实 际 抵达 时 间 、 情 


A. 车 次 B. 日 期 C. 车 次 + 日 期 ”D. 车 次 + 情况 摘要 
8. 己 知 关系 RR 和 S，RNS 等 价 于 
A. (R-S)-S B. S-(S-R) C.(S-R)-R D. S-(R-S) 


9. 学 校 数 据 库 中 有 学 生 和 宿舍 两 个 关系 : 
学 生 (学 号 ， 姓 名 ) 和 宿舍 (楼 名 ， 房 间 号 ， 床 位 号 ， 学 号 ) 
假设 有 的 学 生 不 住宿 , 床位 也 可 能 空闲 。 如 果 要 列 出 所 有 学 生 住宿 和 宿舍 分 配 的 情况 ， 
包括 没有 住宿 的 学 生 和 空闲 的 床位 ， 则 应 执行 
A. 全 外 连接 B. 左 外 连接 C. 右 外 连接 D. 自然 连接 
10. 用 下 面 的 工 SQL 语句 建立 一 个 基本 表 : 
CREATE TABLE Student(Sno CHAR(4) PRIMARY KEY, 
Sname CHAR(8) NOT NULL, 
Sex CHAR(2)， 
Age INT) 
可 以 插入 到 表 中 的 元 组 是 8 
A.'5021'，" 刘 祥 '， 男 ，21 B.NULL，' 刘 祥 '，NULL，21 
C.5021 NULL, 男 , 21 D.'5021'，' 刘 祥 '，NULL,，NULL 
11. 把 对 关系 SPJ 的 属性 QTY 的 修改 权 授予 用 户 李 勇 的 工 SQL 语句 是 
A. GRANT QTY ON SPJ TO ' 李 勇 ' 
B. GRANT UPDATE(QTY) ON SPJ TO ' 李 勇 ' 
C. GRANT UPDATE (QTY) ON SPJ TO 李 勇 
D. GRANT UPDATE ON SPJ (QTY) TO 李 勇 
12. 下 图 中 是 最 小 关系 系统 。 











A. 不 该 删除 的 数据 被 删除 B. 不 该 插入 的 数据 被 插入 
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C. 应 该 删除 的 数据 未 被 删除 D. 应 该 插入 的 数据 未 被 插入 
14. 在 关系 数据 库 设计 中 ， 设 计 关 系 模 式 是 数据 库 设计 中 阶段 的 任务 。 
A.， 逻辑 设计 B. 物理 设计 C. 需求 分 析 D. 概念 设计 
15. 在 E-R 模型 中 ， 如 果 有 3 个 不 同 的 实体 型 ，3 个 M : N 联系 ， 根 据 E-R 模型 转换 
为 关系 模型 的 规则 ， 转 换 后 关系 的 数目 为 
A.4 B.5 C.6 六 学 
16. 事务 的 隔离 性 是 指 a 


LE 


18. 


1 


20. 


A. 一 个 事务 内 部 的 操作 及 使 用 的 数据 对 并 发 的 其 他 事务 是 隔离 的 

B. 事务 一 旦 提交 ， 对 数据 库 的 改变 是 永久 的 

C. 事务 中 包括 的 所 有 操作 要 么 都 做 ， 要 么 都 不 做 

D. 事务 必须 是 使 数据 库 从 一 个 一 致 性 状态 变 到 另 一 个 一 致 性 状态 

数据 库 恢复 的 基础 是 利用 转 储 的 兄 余 数据 ， 这 些 转 储 的 宛 余 数据 是 指  。 
A. 数据 字典 、 应 用 程序 、 审 计 档案 、 数 据 库 后 备 副本 

B. 数据 字典 、 应 用 程序 、 日 志文 件 、 审 计 档 案 

C. 日 志文 件 、 数 据 库 后 备 副 本 

D. 数据 字典 、 应 用 程序 、 数 据 库 后 备 副本 

若 事务 对 数据 对 象 A 加 上 S 锁 , 则 _ . 

A. 事务 工 可 以 读 A 和 修改 A， 其 他 事务 只 能 再 对 A 加 S 锁 ， 而 不 能 加 叉 锁 
B. 事务 T 可 以 读 A 但 不 能 修改 A， 其 他 事务 只 能 再 对 A 加 S 锁 ， 而 不 能 加 义 锁 
C. 事务 T 可 以 读 A 但 不 能 修改 A， 其 他 事务 能 对 A 加 S 锁 和 义 锁 

D. 事务 工 可 以 读 A 和 修改 A， 其 他 事务 能 对 A 加 S 锁 和 XX 锁 




















设 有 两 个 事务 T1、T2， 其 并 发 操作 如 下 图 所 示 ， 下 面 评价 正确 的 是 
Tl T2 
@ 读 A=100 
@ 读 A=100 
@ A=A-5 写 回 
@ A=A-8 写 回 
A. 该 操作 不 存在 问题 B. 该 操作 丢失 修改 
C. 该 操作 不 能 重复 读 D. 该 操作 读 “ 脏 ”数据 
以 下 封锁 违反 两 段 锁 协 议 。 





A. Slock A... Slock B ... Xlock C ...Unlock A... Unlock B ... Unlock C 
B. Slock A ... Slock B ... Xlock C ...Unlock C ... Unlock B .… Unlock A 
C. Slock A ... Slock B ... Xlock C ...Unlock B ... Unlock C ... Unlock A 
D. Slock A ...Unlock A ...SlockB ... Xlock C ...Unlock B ... Unlock C 


、 简 答题 (第 1、3 题 3 分 , 第 2 题 4 分 ， 共 10 分 ) 


1. 试 述 关系 模型 的 参照 完整 性 规则 ? 
2. 试 述 视图 的 作用 ? 
3. 记 日 志文 件 时 必须 遵循 什么 原则 ? 
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四 、 设 计 题 (第 1 题 4 分 , 第 2 题 6 分 , 第 3 题 3 分 , 第 4 题 4 分 , 第 5 题 8 分 , 共 25 分 ) 


1. 设 教学 数据 库 中 有 三 个 基本 表 : 
学 生 表 S(SNO, SNAME, AGE, SEX)， 其 属性 分 别 表 示 学 号 、 学 生 姓名 、 年 龄 、 性 别 。 
课程 表 C(CNO, CNAME, TEACHER)， 其 属性 分 别 表示 课程 号 、 课 程 名 、 授 课 教师 名 。 
选修 表 SC(SNO, CNO, GRADE)， 其 属性 分 别 表 示 学 号 、 课 程 号 、 成 绩 。 
有 如 下 SQL 查询 语句 : 
SELECT CNO 
FROM C 
WHERE CNO NOTIN 
(SELECT CNO 
FROM S,SC 
WHERE S.SNO=SC.SNO 
AND SNAME=' 张 三 "); 
请 完成 下 列 问 题 : 
(1) 阐述 上 述 SQL 语句 的 含义 。 
(2) 等 价 的 关系 代数 表达 式 表示 上 述 SQL 查询 语句 。 
2. 设 有 如 下 图 所 示 的 三 个 关系 。 其 中 各 个 属性 的 含义 如 下 : A#( 商 店 代号 )、 
ANAME( 商 店名 )、WQTY( 店 员 人 数 )、CITY( 所 在 城市 )、B#( 商 品 号 )、 BNAME( 商 品名 称 )、 
PRICE( 价 格 )、QTY( 商 品 数 量 )。 























A 
A# ANAME 
101 韶山 商店 
204 前 门 百货 商店 
256 东风 商场 
345 铁道 商店 
620 第 一 百货 公司 
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试用 SQL 语言 写 出 下 列 查询 : 
(1) 写 出 店员 人 数 不 超 过 100 人 或 者 在 长 沙市 的 所 有 商店 的 代号 和 商店 名 。 
(2) 写 出 至 少 供应 了 代号 为 256 的 商店 所 供应 的 全 部 商品 的 其 他 商店 的 商店 名 和 所 在 




















城市 。 


旦 
本 


3. 设 有 职工 基本 表 : EMP(ENO, ENAME, AGE, SEX, SALARY), 其 属性 分 别 表 示 职 工 
姓名 、 年 龄 、 性 别 、 工 资 。 为 每 个 工资 低 于 1000 元 的 女 职工 加 薪 200 元 ， 试 写 出 这 个 


操作 的 SQL 语句 。 


4. 设 某 工厂 数据 库 中 有 以 下 两 个 基本 表 。 
车 间 基 本 表 : DEPT(DNO, DNAME, MGR_ENO)， 其 属性 分 别 表示 车 间 编 号 、 车 间 名 


和 车 间 主 任 的 职工 号 。 


旦 


每 个 
区 | 
性 有 


工作 ， 工 厂 聘用 职工 有 聘 期 和 工资 。 工 三 的 属性 有 工厂 编号 、 厂 名 、 地 址 ， 产 品 的 属 





职工 基本 表 : ERP(ENO, ENAME, AGE, SEX, SALARY, DNO)， 其 属性 分 别 表示 职工 


号 、 姓 名 、 年 龄 、 性 别 、 工 资 和 所 在 车 间 的 编号 。 


建立 一 个 有 关 女 车 间 主 任 的 职工 号 和 姓名 的 视图 ， 其 结构 如 下 : 

VIEW6(ENO, ENAME)。 

试 写 出 创建 该 视图 VIEW6 的 SQL 语句 。 

5. 设 有 关系 尺 和 函数 依赖 F: R(A, B, C,D, E),F= {ABC—DE, BC—D, DE }。 
试 求 下 列 问 题 : 

(1) 关系 RR 的 侯 选 码 是 什么 ? R 属于 第 几 范 式 ? 并 说 明理 由 。(3 分 ) 

(2) 因果 关系 及 不 属于 BCNF， 请 将 关系 RR 逐步 分 解 为 BCNF。(5 分 ) 

要 求 : 写 出 达到 每 一 级 范式 的 分 解 过 程 ， 并 指明 消除 什么 类 型 的 函数 依赖 。 

五 、 综 合 题 (15 分 ) 


某 企 业 集团 有 若干 工厂 , 每 个 工厂 生产 多 种 产品 , 且 每 一 种 产品 可 以 在 多 个 工厂 生产 ， 
工厂 按照 固定 的 计划 数量 生产 产品 ， 每 个 工厂 聘用 多 名 职工 ， 且 每 名 职工 只 能 在 一 个 














产品 编号 、 产 品名 、 规 格 ， 职 工 的 属性 有 职工 号 、 姓 名 。 
(1) 据 上 述 语 义 画 出 E-R 图 。(5 分 ) 

(2) 该 E-R 模型 转换 为 关系 模型 。(5 分 ) 

(要 求 : 1 : 1 和 1 : n 的 联系 进行 合并 ) 

(3) 写 出 转换 结果 中 每 个 关系 模式 的 主 码 和 外 码 。(5 分 ) 
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模拟 试题 (四 ) 


一 、 填 空 题 ( 共 10 分 ,每 空 1 分 ) 


1. 系数 据 库 的 实体 完整 性 规则 规定 基本 关系 的 都 不 能 取 。 

2. 关系 A(S,SND) 和 BOD,CNNM) 中 ，A 的 主 码 是 S，B 的 主 码 是 D， 则 DD 在 A 中 称 
为 

3. SQL 语言 中 ， 用 于 授权 的 语句 是 

4. 关系 有 与 $ 的 交 可 以 用 关系 代数 的 基本 运算 表示 为 

5. 据 库 系 统 中 最 重要 的 软件 是 ， 最 重要 的 用 户 是 。 

6. 据 库 设计 分 为 以 下 六 个 设计 阶段 : 需求 分 析 阶 段 、 、 逻 辑 结构 设计 阶 
段 、 、 数 据 库 实施 阶段 、 数 据 库 运行 和 维护 阶段 。 

7. 已 知 关系 R(A,B,C,D) 和 R 上 的 函数 依赖 集 F={A 一 CD, C 一 B}, 则 RE NF。 

二 、 单 选 题 ( 共 40 分 ， 每 题 2 分 ) 


1. 下 列 四 项 中 ， 不 属于 数据 库 系 统 的 主要 特点 的 是 5 
A. 数据 结构 化 B. 数据 的 元 余 度 小 
C. 较 高 的 数据 独立 性 D. 程序 的 标准 化 
2. 数据 的 逻辑 独立 性 是 指 
A. 内 模式 改变 ， 模 式 不 变 
B. 模式 改变 ， 内 模式 不 变 
C. 模式 改变 ， 外 模式 和 应 用 程序 不 变 
D. 内 模式 改变 ， 外 模式 和 应 用 程序 不 变 
3. 在 数据 库 的 三 级 模式 结构 中 ， 描 述 数 据 库 中 全 体 数 据 的 全 局 逻辑 结构 和 特征 的 


[a 
在 . o 
































A. 外 模式 B. 内 模式 C. 存储 模式 D. 模式 
4. 相对 于 非 关系 模型 ， 关 系数 据 模型 的 缺点 之 一 是 
A. 存 取 路 径 对 用 户 透明 ， 需 查询 优化 B. 数据 结构 简单 
C. 数据 独立 性 高 D. 有 严格 的 数学 基础 
5. 现 有 关系 表 : 学 生 (宿舍 编号 ， 宿 舍 地 址 ， 学 号 ， 姓 名 ， 性 别 ， 专 业 ， 出 生日 期 ) 的 
主 码 是 5 
A. 宿舍 编号 B. 学 号 
C. 宿舍 地 址 ， 姓 名 D. 宿舍 编号 ， 学 号 


6. 自然 连接 是 构成 新 关系 的 有 效 方法 。 一 般 情况 下 ， 当 对 关系 R 和 S 使 用 自然 连接 
时 ， 要 求 R 和 S 含有 一 个 或 多 个 共有 的 。 
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A. 元 组 B. 行 C. 记录 D. 属性 
7. 下 列 关系 运算 中 ， 运算 不 属于 专门 的 关系 运算 。 

A. 选择 B. 连接 C. 广义 笛 卡 尔 积 D. 投影 
8. SQL 语言 具有 的 功能 。 


A. 关系 规范 化 、 数 据 操纵 、 数 据 控制 

B. 数据 定义 、 数 据 操纵 、 数 据 控制 

D. 数据 定义 、 关 系 规范 化 、 数 据 操纵 

9. 从 E-R 模型 关系 向 关系 模型 转换 时 ， 一 个 M : N 联系 转换 为 关系 模式 时 ， 该 关系 

模式 的 关键 字 是 

A. M 端 实体 的 关键 字 

B.N 端 实体 的 关键 字 

C. M 端 实体 关键 字 与 N 端 实体 关键 字 组 合 











D. 重新 选取 其 他 属性 
10. SQL 语言 中 ， 删 除 一 个 表 的 命令 是 。 
A.DELETE B.DROP CC.CLEAR D. REMOVE 
11. 下 图 中 是 关系 完备 的 系统 。 
/网 MA 
WSI) 
A B D 


12. 有 关系 模式 A(S,C,M)， 其 中 各 属性 的 含义 是 ，S 为 学 生 ，C 为 课程 ，M 为 名 次 ， 
其 语义 是 : 每 一 个 学 生 选 修 每 门 课程 的 成 绩 有 一 定 的 名 次 ， 每 门 课程 中 每 一 名 次 只 有 一 个 


学 生 ( 即 没有 并 列 名 次 )， 则 关系 模式 A 最 高 达到 
A. INF B. 2NF C.3NF D. BCNF 
13. 关系 规范 化 中 的 删除 异常 是 指 。 


A. 不 该 删除 的 数据 被 删除 B. 不 该 插入 的 数据 被 插入 
C. 应 该 删除 的 数据 未 被 删除 ” ”D. 应 该 插入 的 数据 未 被 插入 


14. 在 数据 库 设 计 中 ，E-R 图 产生 于 总 
A， 需 求 分 析 阶 段 B. 物理 设计 阶段 
C. 逻辑 设计 阶段 D. 概念 设计 阶段 














15. 有 一 个 关系 : 学 生 ( 学 号 , 姓名 , 系 别 ), 规定 学 号 的 值 域 是 8 个 数字 组 成 的 字符 串 ， 
这 一 规则 属于 
A. 实体 完整 性 约束 B. 参照 完整 性 约束 
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C. 用 户 自 定义 完整 性 约束 D. 关键 字 完 整 性 约束 
16. 事务 是 数据 库 运 行 的 基本 单位 。 如 果 一 个 事务 执行 成 功 ， 则 全 部 更 新 提交 ; 如 果 
一 个 事务 执行 失败 ， 则 已 做 过 的 更 新 被 恢复 原状 ， 好 像 整 个 事务 从 未 有 过 这 些 更 新 ， 这 样 
保持 了 数据 库 处 于 状态。 

















A. 安全 性 B. 一 致 性 C. 完整 性 D. 可 靠 性 
17. 用 来 记录 对 数据 库 中 数据 进行 的 每 一 次 更 新 操作 。 
A. 后 援 副本 B. 日 志文 件 C. 数据 库 D. 缓冲 区 
18. 在 并 发 控制 技术 中 ， 最 常用 的 是 封锁 机 制 ， 基 本 的 封锁 类 型 有 排 它 锁 X 和 共享 锁 
S， 下 列 关 于 两 种 锁 的 相 容 性 描述 不 正确 的 是 
A.X/X: TRUE B. S/S: TRUE 
C. S/X: FALSE D.XS: FALSE 
19. 设 有 两 个 事务 T1、T2， 其 并 发 操作 如 下 图 所 示 ， 下 面 评价 正确 的 是 ; 
A. 该 操作 不 存在 问题 B. 该 操作 丢失 修改 
C. 该 操作 不 能 重复 读 D. 该 操作 读 “ 脏 ”数据 
号 
ee read(A) 
0 
read(A) 
read(B) 
A 





20. 已 知事 务 T1 的 封锁 序列 为 : LOCK S(A)…LOCK S(B)…LOCK X(C)…UNLOCK 
(B) …UNLOCK (A) …UNLOCK (C) 

事务 T2 的 封锁 序列 为 : LOCK S(A) …UNLOCK (A) …LOCK SGB)…LOCK X(C) … 
UNLOCK (C) …UNLOCK (B) 

则 遵守 两 段 封锁 协议 的 事务 是 

ATI1 B.T2 CTI 和 T2 D. 没 有 

三 、 简 答题 (第 1 题 4 分 ,第 2、3 题 各 3 分 ， 共 10 分 ) 

1. 试 述 数据 、 数 据 库 、 数 据 库 管理 系统 、 数 据 库 系统 的 概念 。 

2. 说 明 视图 与 基本 表 的 区 别 和 联系 。 

3. 数据 库 系 统 的 故障 有 哪些 类 型 ? 

四 、 设 计 题 (第 1 题 15 分 ， 第 2 题 10 分 ， 共 25 分 ) 

1. 设 有 一 个 工程 供应 数据 库 系统 ， 包 括 如 下 四 个 关系 模式 : 

S(SNO, SNAME. STATUS. CITY); 

P(PNO, PNAME, COLOR. WEIGHT); 

JQNO.JNAME,. CITY); 
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SPJ(SNO. PNO. JNO. QTY). 
供应 商 表 S 由 供应 商号 、 供 应 商 名 、 状 态 、 城 市 组 成 
零件 表 P 由 零件 号 、 零 件 名 、 颜 色 、 重 量 组 成 
工程 项 目 表 了 由 项 目 号 、 项 目 名 、 城 市 组 成 ; 
供应 情况 表 SPJ 由 供应 商号 、 零 件 号 、 项 目 号 、 供 应 数量 组 成 。 
(1) 用 关系 代数 查询 没有 使 用 天 津 供 应 商 生产 的 红色 零件 的 工程 号 。(3 分 ) 
(2) 用 关系 代数 查询 至 少 使 用 了 供应 商 S1 所 供应 的 全 部 零件 的 工程 号 INO。(3 分 ) 
(3) 用 SQL 查询 供应 工程 和 1 零件 为 红色 的 工程 号 JNO。C 分 ) 
(4) 用 SQL 查询 没有 使 用 天 津 供应 商 生 产 的 零件 的 工程 号 。(3 分 ) 
(5) 用 SQL 语句 将 全 部 红色 零件 改 为 蓝 色 。(2 分 ) 
(6) 用 SQL 语句 将 (S2, P4, J6, 400) 插 入 供应 情况 关系 。(2 分 ) 
2. 设 有 关系 STUDENT(S#.SNAME,SDEPT,MNAME,CNAME,GRADE), (S#.CNAME) 
为 候选 码 ， 设 关系 中 有 如 下 函数 依赖 : 
(S#CNAME) 一 SNAME,SDEPTMNAME 
S# 一 SNAME,SDEPTMNAME 
(S#CNAME) 一 GRADE 
SDEPT 一 MNAME 
试 求 下 列 问题 : 
(1) 关系 STUDENT 属于 第 儿 范式 ? 并 说 明理 由 。(3 分 ) 
(2) 如 果 关 系 STUDENT 不 属于 BCNF, 请 将 关系 STUDENT 逐步 分 解 为 BCNF。(7 分 ) 
要 求 : 写 出 达到 每 一 级 范式 的 分 解 过 程 ， 并 指明 消除 什么 类 型 的 函数 依赖 。 
五 、 综 合 题 (15 分 ) 


某 医院 病房 管理 系统 中 ， 包 括 四 个 实体 型 ， 分 别 为 : 






































科室 ， 科 名 、 科 地 址 、 科 电话 病房 : 病房 号 、 病 房 地 址 

医生 ， 工 作证 号 、 姓 各、 职称、 年 龄 病人 : 病历 号 、 姓 名 、 性 别 。 

且 存在 如 下 语义 约束 : 

。 一 个 科室 有 多 间 病 房 、 多 个 医生 ， 一 个 病房 只 能 属于 一 个 科室 ， 一 个 医生 只 属于 
一 个 科室 ; 


。 一 个 医生 可 负责 多 个 病人 的 诊治 ， 一 个 病人 的 主管 医生 只 有 一 个 ; 
。 一 间 病 房 可 入 住 多 个 病人 ， 一 个 病人 只 能 入 住 在 一 间 病 房 。 
注意 : 不 同 科室 可 能 有 相同 的 病房 号 。 

完成 如 下 设计 : 
(1) 画 出 该 医院 病房 管理 系统 的 E-R 图 。(5 分 ) 

(2) 将 该 E-R 图 转换 为 关系 模型 。(5 分 ) 

(要 求 : 1 : 1 和 1 : n 的 联系 进行 合并 ) 

(3) 指出 转换 结果 中 每 个 关系 模式 的 主 码 和 外 码 。(5 分 ) 
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模拟 试题 五) 


、 填 空 题 ( 共 10 分 ， 每 空 1 分 ) 
1. 关系 数据 的 数据 完整 性 约束 包括 实体 完整 性 
2. 在 对 表 中 的 数据 进行 修改 时 ， 对 数据 实施 完整 性 检查 激活 的 触发 器 是 
3. 连接 运算 中 有 两 种 最 为 重要 也 最 为 常用 的 连接 , 一 种 是 等 值 连接 , 另 一 种 是 
4. 
入 




















在 SQL 语句 中 ,使 用 语句 来 建立 索引 。 

. 如 果 要 计算 表 中 数据 的 平均 值 ， 可 以 使 用 的 聚合 函数 是 

6. 在 SQL Server 中 ， 为 便于 管理 用 户 及 权限 ， 可 以 将 一 组 具有 相 辣 权限 的 用 户 组 织 
在 一 起 ， 这 一 组 具有 相同 权限 的 用 户 称 为 

7. 从 关系 规范 化 理论 的 角度 来 讲 ， 一 个 只 满足 1NF 的 关系 可 能 存在 四 方面 的 问题 
数据 宛 余 度 大 、 修 改 异 常 、 插 入 异常 和 _ 

8. 若 一 个 视图 是 从 单个 基本 表 导 出 的 ， 并 且 只 是 去 掉 了 基本 表 的 某 些 行 和 某 些 列 ， 但 
保留 了 主 码 ， 我 们 称 这 类 视图 为 

9. 设 有 下 列 关系 模式 R,， FF 是 RR 上 成 立 的 函数 依赖 集 ，R(A., B, C) ，F={B 一 C, AC 一 
B}，R 属于 范式 。 

10. 关系 模式 R(U,F) 中 ，U=ABCD.F={A 一 C,C 一 A,B 一 AC.D 一 AC}，R 的 候选 键 











为 
二 、 选 择 题 ( 共 30 分 ， 每 题 2 分 ) 
- 数据 库 与 文件 系统 的 根本 区 别 在 于 





王 





A. 提高 了 系统 效率 B. 方便 了 用 户 使 用 
C. 数据 的 结构 化 D. 节省 了 存储 空间 


2. 要 保证 数据 库 的 逻辑 数据 独立 性 ， 需 要 修改 的 是 
A. 模式 与 外 模式 之 间 的 映射 B. 模式 与 内 模式 之 间 的 映射 





C. 模式 D. 三 级 模式 
3. 五 种 基本 关系 代数 运算 是 
A. U, —, [xd ，I 和 vc B. U， 一 ，X，I 和 oo 
和 6 D. U, NM, DIq, HI 和 o 
4. 下 列 聚 集 函 数 中 不 忽略 空 值 NULL) 的 是 
A. SUM( 列 名 ) B. MAX( 列 名 ) 
C. COUNT(*) D. AVG( 列 名 ) 


5. 在 视图 上 不 能 完成 的 操作 是 
A. 更 新 视图 B. 在 视图 上 定义 新 的 视图 
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C. 查询 D. 在 视图 上 定义 新 的 表 
6. 下 列 的 SQL 语句 中 ， 不 是 数据 定义 语句 。 
A. CREATE TABLE B. DROP VIEW 
C. CREATE VIEW D. GRANT 
7. 车 要 撤销 数据 库 中 已 经 存在 的 表 B, 可 用 。 
A. DELETE TABLE B B. DROP TABLEB 
C. DELETEB D. DROPB 
8. 如 果 要 在 一 张 管理 职工 工资 的 表 中 限制 工资 的 输入 范围 ， 应 使 用 约束 。 
A. PDRIMARY KEY ~ B. FOREIGN KEY 
C. UNIQUE D. CHECK 
9. SQL 聚集 函数 COUNT、SUM、AVG、MAX、MIN 不 允许 出 现在 查询 语句 
句 中 。 
A. SELECT B. HAVING 
C. WHERE D. GROUPBY... HAVING 
10. 在 SQL SERVER 中 局 部 变量 前 面 的 字符 为 
A.@@ B.# 人 D.@ 
11. 设 关 系 RR 和 S 的 属性 个 数 分 别 为 r 和 s, 则 (RxS) 操 作 结果 的 属性 个 数 为 
A.rxs Bs Ce D. max(r,s) 
12. 关 系 模型 概念 中 ， 不 含 多 余 属 性 的 超 键 称 为 。 





A. 候选 码 B. 超 码 C. 全 码 D. 主 码 
13. 有 关系 S(S#.SNAME,SEX),C(C#.CNAME),SC(S#.C 才 。 其 中 S# 为 学 生 号 ,SNAME 
为 学 生 姓 名 ，SEX 为 性 别 ，C# 为 课程 号 ，CNAME 为 课程 名 。 要 查询 选修 “计算 机 ” 课 的 
全 体 女 学 生 姓名 的 SQL 语句 是 SELECT SNAME FROM S，C，SC WHERE 子 句 。 这 里 
WHERE 子 句 的 内 容 是 
A. S.S#-SC.S# AND SEX=' 女 'AND CNAME=' 计 算 机 ' 
B. S$.S#=SC.S# AND C.C#=SC.C#AND CNAME=' 计 算 机 ' 
C. SEX=' 女 'AND CNAME=' 计 算 机 ' 
D. S.S#=SC.S# AND C.C#=SC.C# AND SEX=' 女 'AND CNAME=' 计 算 机 
14. 在 下 面 的 两 个 关系 中 ， 职 工 号 和 部 门 号 分 别 为 职工 关系 和 部 门 关 系 的 主 码 。 
职工 (职工 号 、 职 工 名 、 部 门 号 、 职 务 、 工 资 ) 
部 门 (部 门 号 、 部 门 名 、 部 门人 数 、 工 资 总 额 ) 
在 这 两 个 关系 的 属性 中 ， 只 有 一 个 属性 是 外 键 ， 它 是 








A. 职工 关系 的 “职工 号 ” B. 职 工 关系 的 “部 门 号 ” 
C. 部 门 关 系 的 “部 门 号 ” D. 部 门 关系 的 “部 门 名 ” 
15. 要 查询 XSH 数据 库 CP 表 中 产品 名 含有 “冰箱 ”的 产品 情况 , 可 用 命令 。 


A. SELECT* FROM CP WHERE 产品 名 称 =% 冰 箱 %6' 
B. SELECT* FROM CP WHERE 产品 名 称 =' 冰箱 ， 
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C. SELECT* FROM CP WHERE 产品 名 称 LIKE% 冰 箱 %' 
D. SELECT * FROM CP WHERE 产品 名 称 LIKE' 冰箱 ，' 


三 、 判 断 题 ( 共 10 分 ， 每 题 1 分 ) 

1. SQL 语言 是 关系 数据 库 的 标准 语言 。 
2. 关系 数据 库 是 采用 关系 模型 作为 数据 的 组 织 方式 。 
3. 外 模式 /模式 映像 保证 了 数据 的 物理 独立 性 。 

4. 程序 的 标准 化 是 数据 库 技 术 的 主要 特点 。 
5 
6. 





一 一 一 一 一 


. 使 用 INSERT 命令 一 次 只 能 插入 一 行 数据 。 














. 日 志文 件 用 于 存放 恢复 数据 库 用 的 所 有 日 志 信息 , 每 个 数据 库 至 少 拥有 一 个 日 志 
件 ， 也 可 以 拥有 多 个 日 志文 件 ， 扩 展 名 为 ldf。 

7. SQL Server 存储 过 程 能 够 立即 访问 数据 库 。 

8. 空 值 与 任何 非 空 值 的 运算 结果 都 是 空 值 。 

9. 在 SELECT 语句 中 ， 使 用 GROUP BY 子 句 时 ， 一 定 要 有 HAVING 子 句 。 

10. 若 关 系 模式 R 中 的 属性 全 部 是 主 属性 ， 则 R 必定 是 BCNF。 

四 、 设 计 题 (15 分 ) 

某 工厂 要 开发 商品 销售 与 库存 子 系统 ， 经 需求 分 析 后 得 出 以 下 结论 。 

e。 有 若干 商店 ， 包 括 商 店 号 、 商 店名 、 地 点 、 经 理 。 

e 有 若干 商品 ， 包 括 商 品 号 、 商 品名 、 规 格 、 单 价 。 

e。 有 若干 仓库 ， 包 括 仓 库 号 、 仓 库 名 、 地 点 、 面 积 、 负 责 人 。 

。 每 个 商店 可 销售 多 种 商品 ， 每 种 商品 可 在 多 个 商店 销售 。 

。 每 种 商品 可 在 多 座 仓库 存储 ， 每 座 仓 库 可 以 存储 多 种 商品 。 

e 商店 销售 商品 ， 包 括 销售 日 期 和 销售 数量 。 

e 仓库 存储 商品 ， 包 括 入 库 日 期 和 存储 数量 。 

请 根据 需求 分 析 结 论 完 成 概念 结构 设计 和 由 辑 结构 设计 。 

(1) 绘制 每 个 实体 E-R 图 ， 并 在 图 中 标 出 主 码 。(6 分 ) 

(2) 进行 系统 概念 结构 设计 ， 绘 制 全 局 E-R 图 。(6 分 ) 

(3) 进行 系统 逻辑 结构 设计 ， 写 出 关系 模式 。(3 分 ) 


五 、 综 合 题 (第 1 题 10 分 ,第 2 题 10 分 , 第 3 题 15 分 ) 


1. 已 知 关系 模式 R(U.F) 中 ，U={ABCD}, F={A 一 C,C 一 A,B 一 AC,D 一 AC}。 完 成 以 下 
计算 : 

(1) (AD)r。(4 分) 

(2) F 的 最 小 函数 依赖 集 。(6 分 ) 

2. 设 有 3 个 关系 STUDENT、COURSE 和 SC， 其 关系 模式 分 别 如 下 所 示 : 

学 生 关系 STUDENT(SNO,SNAME.AGE.SEX)， 其 中 ，SNO 为 学 号 ,， SNMAE 为 姓名 ， 
AGE 为 年 龄 ，SEX 为 性 别 。 





让 
Si ee Sa ol et i ti Si i 


一 一 一 一 一 
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课程 关系 COURSE (CNO,CNAME,TEACHER)， 其 中 ，CN0O 为 课程 号 ，CNAME 为 课 
程 名 ，TEACHER 为 授课 教师 。 

选修 关系 SC(SNO,CNO,GRADE)， 其 中 ，SNO 为 学 号 ，CNO 为 课程 号 ，GRADE 为 

试用 关系 代数 表达 式 表示 下 列 查 询 : 

(1) 查询 年 龄 小 于 20 岁 的 学 生 的 学 号 和 姓名 。(3 分 ) 

(2) 查询 选修 了 课程 号 为 C2 的 学 生 学 号 与 成 绩 。(3 分 ) 

(3) 检索 选修 课程 名 为 “图 像 处 理 ” 的 学 生 学 号 。(4 分 ) 

3. 根据 题 意 要 求 ， 使 用 标准 SQL 语言 完成 下 列 查 询 。 

设 有 如 下 学 生 选 课 数据 库 ， 它 包括 学 生 关 系 、 课 程 关 系 和 选课 关系 ， 其 关系 模式 为 ; 

学 生 ( 学 号 ， 姓 名 ， 年 龄 ， 性 别 ， 系 部 ); 

课程 (课程 号 ， 课 程 名 ， 教 师 ); 

选课 (学 号 ， 课 程 号 ， 成 绩 )。 

(1) 查询 选修 C1 课程 且 成 绩 大 于 90 分 的 学 生 学 号 和 成 绩 ， 并 要 求 对 查询 结果 按 成 绩 
的 降序 排列 ， 如 果 成 绩 相 同 则 按 学 号 的 升序 排列 。(2 分 ) 

(2) 查询 名 字 中 第 二 个 字 为 “ 阳 ” 的 学 生 的 姓名 和 选课 成 绩 。(2 分 ) 

(3) 检索 选修 了 2 门 以 上 课程 的 学 生 学 号 及 其 选课 门 数 。(2 分 ) 

(4) 查询 选修 了 C2 课程 的 学 生 姓 名 。(2 分 ) 

(5) 用 带 IN 谓词 的 子 查询 查询 选修 了 C2 课程 的 学 生 姓 名 。(3 分 ) 

(6) 用 带 EXISTS 谓词 的 相关 子 查询 查询 选修 了 C2 课程 的 学 生 姓 名 。(4 分 ) 
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